سلام
apache cordova را نصب کنید(آموزش نصب):
npm install -g cordova
سپس پروژه را با نام و باندل مورد نظر نصب کنید:
cordova create mashinhesab ir.gitrepo.mashinhesab
وارد پوشه ساخته شده برای نرم افزار خود شوید:
cd mashinhesab
پلتفرم مورد نظر خروجی نرم افزار را مطابق آموزش های قبلی نصب کنید. من اینجا Android و نسخه مرورگر Browser را نصب می کنم.
cordova platform add android
حال سورس نرم افزار را در پوشه www جایگزین کنید
شما اینجا سه فایل اصلی دارید:
index.html
<!DOCTYPE html> <!--- www.gitrepo.ir---> <html> <head> <meta charset="utf-8" /> <title>ماشین حساب پیشرفته</title> <link rel="stylesheet" href="css/style.css" /> </head> <body> <div class="mashinhesab"> <h2 class="title">ماشین حساب</h2> <input type="text" id="display" disabled /> <div class="buttons"> <button onclick="press('7')">7</button> <button onclick="press('8')">8</button> <button onclick="press('9')">9</button> <button class="operator" onclick="press('/')">÷</button> <button onclick="press('4')">4</button> <button onclick="press('5')">5</button> <button onclick="press('6')">6</button> <button class="operator" onclick="press('*')">×</button> <button onclick="press('1')">1</button> <button onclick="press('2')">2</button> <button onclick="press('3')">3</button> <button class="operator" onclick="press('-')">−</button> <button onclick="press('0')">0</button> <button onclick="press('.')">.</button> <button class="equal" onclick="calculate()">=</button> <button class="operator" onclick="press('+')">+</button> <button class="clear" onclick="clearDisplay()">C</button> </div> <button class="theme-toggle" onclick="toggleTheme()">🌓 تغییر رنگ</button> <ul id="history" class="history"></ul> <button class="clear-history" onclick="clearHistory()">🗑️ پاک کردن تاریخچه</button> </div> <img src="" data-wp-preserve="%3Cscript%20src%3D%22js%2Fapp.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object mce-object-script" width="20" height="20" alt="<script>" /> </body> </html>
فایل style.css
body { font-family: 'Tahoma', sans-serif; background: linear-gradient(to right, #dfe9f3, #ffffff); display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0; } .mashinhesab { background-color: #ffffff; padding: 20px 25px; border-radius: 20px; box-shadow: 0 10px 25px rgba(0,0,0,0.1); width: 260px; text-align: center; } .mashinhesab h2 { margin-bottom: 15px; color: #333; } #display { width: 100%; height: 45px; font-size: 22px; margin-bottom: 15px; text-align: right; padding-right: 10px; border: none; border-bottom: 2px solid #ccc; background: #f9f9f9; border-radius: 8px; } .buttons { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; } button { height: 50px; font-size: 20px; border: none; border-radius: 12px; background-color: #f1f1f1; color: #333; transition: 0.2s; cursor: pointer; } button:hover { background-color: #e0e0e0; } .operator { background-color: #ffb84d; } .operator:hover { background-color: #ffa31a; } .equal { background-color: #4CAF50; color: white; } .equal:hover { background-color: #45a049; } .clear { grid-column: span 4; background-color: #f44336; color: white; } .clear:hover { background-color: #d32f2f; } .title { color: #333; } .dark-theme .title { color: #eee; } .dark-theme { background: linear-gradient(to right, #333, #222); color: #eee; } .dark-theme .mashinhesab { background-color: #2c2c2c; box-shadow: 0 10px 25px rgba(0,0,0,0.4); } .dark-theme #display { background: #444; color: #fff; border-bottom: 2px solid #888; } .dark-theme button { background-color: #555; color: #eee; } .dark-theme button:hover { background-color: #666; } .history { margin-top: 15px; text-align: right; max-height: 100px; overflow-y: auto; font-size: 14px; color: #666; } .dark-theme .history { color: #ccc; } .theme-toggle { margin-top: 10px; background-color: #888; color: white; border: none; padding: 8px 12px; border-radius: 10px; cursor: pointer; } .theme-toggle:hover { background-color: #777; } .clear-history { margin-top: 8px; background-color: #b71c1c; color: white; border: none; padding: 8px 12px; border-radius: 10px; cursor: pointer; } .clear-history:hover { background-color: #a31414; }
فایل app.js
let current = ''; let history = []; function press(val) { current += val; document.getElementById('display').value = current; } function calculate() { try { const result = eval(current).toString(); history.push(current + ' = ' + result); updateHistory(); current = result; document.getElementById('display').value = current; } catch (e) { document.getElementById('display').value = 'Error'; current = ''; } } function clearDisplay() { current = ''; document.getElementById('display').value = ''; } function updateHistory() { const historyList = document.getElementById('history'); historyList.innerHTML = ''; for (let i = history.length - 1; i >= 0 && i >= history.length - 5; i--) { const item = document.createElement('li'); item.textContent = history[i]; historyList.appendChild(item); } } function toggleTheme() { document.body.classList.toggle('dark-theme'); } function clearHistory() { history = []; updateHistory(); } // صدا const clickSound = new Audio('assets/click.mp3'); // بررسی ویبره پشتیبانی شده function vibrate(ms = 50) { if (navigator.vibrate) { navigator.vibrate(ms); } } // افزودن صدا و ویبره به رویدادهای کلیدی document.querySelectorAll('button').forEach(btn => { btn.addEventListener('click', () => { clickSound.currentTime = 0; clickSound.play(); vibrate(); }); });
حال پروژه را اجرا کنید:
cordova run Browser
برای آندروید
cordova run android