#javascript #html #css #wordpress
Вопрос:
Я воссоздаю калькулятор на основе javascript на тестовом сайте здесь: https://verbal-masai.jurassic.ninja/calculator/. Вдохновленный этим сайтом: https://thevegancalculator.com/#calculator.
Итак, я добавил коды javascript и css на свой сайт (прилагается ниже). Я разработал страницу с использованием html. Но по какой-то причине, когда я нажимаю «рассчитать«, ничего не происходит. Я почти уверен, что проблема в моем html, который неправильно ссылается на код js, поэтому ничего не происходит. Ниже приведен html-код, который я использовал для поля «месяцы», кнопки «рассчитать» и поля «галлоны воды». Если кто-то может указать, чего мне не хватает в полях html, я могу сам исправить другие поля html. Спасибо.
В инструментах разработки Chrome я вижу две ошибки, но не знаю, как их исправить.
Ошибка 1:
Uncaught SyntaxError: Unexpected token '<'
Ошибка 2:
Uncaught ReferenceError: veganCalc is not defined at HTMLSpanElement.onclick
Примечание: Эта страница размещена по адресу https://jurassic.ninja, который является сайтом для тестирования wordpress, поэтому, если вам нужен внутренний доступ для устранения неполадок, дайте мне знать, и я предоставлю информацию для входа.
Код JS
var formatNumber = function (x) {
return x.toString().replace(/B(?=(d{3}) (?!d))/g, ",");
};
var kgToLb = function () {
return v * 2.20462;
};
var lbToKg = function () {
return v / 2.20462;
};
var gallonToLitre = function () {
return v * 3.7854;
};
var litreToGallon = function () {
return v / 3.7854;
};
var sqftToSqm = function () {
return v * 0.0929;
};
var sqmToSqft = function () {
return v / 0.0929;
};
function veganCalc () {
var unit;
var totalDays = 0;
var years = $('#years').val();
var month = $('#months').val();
totalDays = (month) ? totalDays month*30 : totalDays ;
totalDays = (years) ? totalDays years*365 : totalDays ;
// Variables
var indexes = {
'gallons': {
'ipd': {
'imperial': 1100,
'metric': 4163.9
},
'selector': '.water',
'index': {
'imperial': 'Gallons of water:',
'metric': 'Litres of water:'
}
},
'grains': {
'ipd': {
'imperial': 40,
'metric': 18.1
},
'selector': '.grain',
'index': {
'imperial': 'lbs of Grain:',
'metric': 'kg of Grain:'
}
},
'forest': {
'ipd': {
'imperial': 30,
'metric': 2.8
},
'selector': '.forest',
'index': {
'imperial': 'Sq.ft of Forest:',
'metric': 'Sq.m of Forest:'
}
},
'co2': {
'ipd': {
'imperial': 20,
'metric': 9.1
},
'selector': '.co2',
'index': {
'imperial': 'lbs of Co2:',
'metric': 'kg of Co2:'
}
},
'animals': {
'ipd': {
'imperial': 1,
'metric': 1
},
'selector': '.animals',
'index': {
'imperial': 'Animal Lives:',
'metric': 'Animal Lives:'
}
}
}
// Functions
var years = $('#years').val();
var months = $('#months').val();
var unit = $('#unit').val();
//Prints
$.map(indexes, function (v, i) {
$(v.selector ".index").html(v.index[unit]);
$(v.selector ".value").html(formatNumber( Math.round(v.ipd[unit] * totalDays) ) );
});
$('.intro.index').html("You have saved:");
};
Код CSS
.index.intro {
text-align: center;
color: #2cc03d;
margin-bottom: 0;
font-style: italic;
}
input[type="number"] {
height: 3rem;
background-color: #ccc;
font-size: 1.2rem;
}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
opacity: 1;
}
input[type="text"], input[type="password"], input[type="date"], input[type="datetime"], input[type="datetime-local"], input[type="month"], input[type="week"], input[type="email"], input[type="number"], input[type="search"], input[type="tel"], input[type="time"], input[type="url"], input[type="color"] {
-webkit-appearance: none;
border-radius: 0;
background-color: #FFFFFF;
font-family: inherit;
border-style: solid;
border-width: 1px;
border-color: #cccccc;
box-shadow: inset 0 1px 2px rgb(0 0 0 / 10%);
color: rgba(0, 0, 0, 0.75);
display: block;
font-size: 0.875rem;
margin: 0 0 1rem 0;
padding: 0.5rem;
height: 2.3125rem;
width: 100%;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
transition: box-shadow 0.45s, border-color 0.45s ease-in-out;
}
.calculator .button {
margin-top: 1.3rem;
}
.postfix, .button {
padding: 0 0 0 0;
text-align: center;
border: none;
display: block;
width: 100%;
}
.calculator-btn {
color: #fff;
}
.button {
background-color: #f92f4c;
font-size: 100%;
height: 3rem;
line-height: 3rem;
}
.calculator .name {
border: none;
box-shadow: none;
color: #2cc03d;
font-size: 0.8rem;
padding: 0.3rem 1rem;
display: inline;
position: relative;
left: 0;
top: 0;
font-weight: bold;
text-transform: uppercase;
}
.calculator .number {
padding: 0.25rem 1rem;
font-size: 1.8rem;
color: #fff;
display: block;
margin: 0;
background: #1CB53D;
}
Месяцы HTML
<label for="months">Months:</label>
<input type="number" id="months" min="0" max="12">
HTML кнопки
<a href="#calculator">
<span class="button postfix calculator-btn" onclick="veganCalc()">Calculate</span></a>
Галлоны воды HTML
<div class="stat">
<div class="name box-shadow index water">Gallons of water:</div>
<div class="number value water">0</div>
</div>
Комментарии:
1. Откройте консоль инструментов разработки/JavaScript вашего браузера (обычно клавиша F12) и найдите ошибки. Когда вы нажимаете вычислить:
Uncaught TypeError: $ is not a function
скорее всего, ваш код использует синтаксис jQuery, но вы не включаете библиотеку.2. Попробуйте изменить свой «$» на «jQuery».
3. В вашем HTML, похоже, нет ввода лет, но ваши ссылки на JS #лет. Если это так, вы должны видеть ошибку в консоли инструментов разработки вашего браузера.
4. Вам нужно добавить » v «в качестве параметра в свои функции, например, «x» в первой? Я просто бегло просмотрел.
5. Я попытался изменить «$» на «jQuery» в своем js-скрипте. Но инструменты разработки также сообщают мне, что в моей html-кнопке » veganCalc ()»есть ошибка. Я не знаю, что/как это изменить. Кроме того, теперь я получаю не эту ошибку, а две новые (перечисленные в описании выше).
Ответ №1:
Наконец-то это работает! Спасибо @ugene за комментарий, чтобы изменить $ на jQuery. После этого все сработало. Для тех, кто еще ищет ответ, надеюсь, это поможет. WordPress поставляется со своей собственной библиотекой jQuery и по умолчанию находится в «режиме совместимости», поэтому он не конфликтует с другими библиотеками javascript. Это также означает, что $ не будет работать в вашем сценарии. Просто измените это на jQuery, и все остальное встанет на свои места, при условии, что ваш HTML правильно закодирован.