3
레일스에서이 페이지에 들어가면 자바 스크립트가로드되지 않는 문제가 있습니다. 페이지를 입력 한 후 페이지를 다시로드해야만로드됩니다.레일이 페이지를 다시로드 한 후에 만 자바 스크립트를로드합니다.
$(function() {
initPage();
});
$(window).bind('page:change', function() {
initPage();
});
function initPage() {
window.onload = function() {
var div = document.getElementById("buttons");
var btn1 = document.createElement("button"); btn1.innerHTML = "Add one calculator"; btn1.id = "one";
div.appendChild(btn1);
btn1.onclick = function() {make_buttons ('calc');};
};
function make_buttons (id) {
var div_id = Math.floor(Math.random()*999);
var input_id = Math.floor(Math.random()*999);
var operators = ["*","/","+","-","=","c","DEL"];
var parent = document.getElementById(id);
var in_div = document.createElement("div"); in_div.id = div_id;
parent.appendChild(in_div);
var input = document.createElement("input"); input.type = 'text'; input.id = input_id; input.readOnly=true;
in_div.appendChild(input);
for (var i = 0;i < 10; i++){ // make buttons with numbers
var btn = document.createElement ("button");
if (i === 0 || i === 6) {
var br = document.createElement("br");
in_div.appendChild(br);
}
btn.innerHTML = i;
btn.id = i;
in_div.appendChild(btn);
(function(index) {btn.onclick = function() {document.getElementById(input_id).value += index;};})(i);
}
for (var j = 0; j < operators.length; j++) { // make buttons with operators
var btn = document.createElement ("button");
btn.innerHTML = operators[j];
btn.id = operators[j];
in_div.appendChild(btn);
if (operators[j] === "=") {
btn.onclick = function() {document.getElementById(input_id).value = eval(document.getElementById (input_id).value);};
}
else if (operators[j] === "c") {
btn.onclick = function() {document.getElementById(input_id).value = '';};
}
else if (operators[j] === "DEL") {
btn.onclick = function() {clearBox(div_id);};
}
else {
(function(index) {btn.onclick = function() {document.getElementById(input_id).value += index;};})(operators[j]);
}
};
};
function clearBox(elementID) // delete the selected instance of calc
{
document.getElementById(elementID).innerHTML='';
}
}
이 또한 내가 레일의 turbolinks 기능을 사용하고 있습니다 :
이처럼 내 자바 스크립트 파일의 모습입니다. 여기에 무슨 문제가 있을까요?
새 코드;
$(document).ready(function() {initPage();});
window.on('page:change', function(){initPage();});
/*
$(function() {
initPage();
});
$(window).bind('page:change', function() {
initPage();
});
*/
function initPage() {
var div = document.getElementById("buttons");
var btn1 = document.createElement("button"); btn1.innerHTML = "Add one calculator"; btn1.id = "one";
div.appendChild(btn1);
btn1.onclick = function() {make_buttons ('calc');};
}
function make_buttons (id) {
var div_id = Math.floor(Math.random()*999);
var input_id = Math.floor(Math.random()*999);
var operators = ["*","/","+","-","=","c","DEL"];
var parent = document.getElementById(id);
var in_div = document.createElement("div"); in_div.id = div_id;
parent.appendChild(in_div);
var input = document.createElement("input"); input.type = 'text'; input.id = input_id; input.readOnly=true;
in_div.appendChild(input);
for (var i = 0;i < 10; i++){ // make buttons with numbers
var btn = document.createElement ("button");
if (i === 0 || i === 6) {
var br = document.createElement("br");
in_div.appendChild(br);
}
btn.innerHTML = i;
btn.id = i;
in_div.appendChild(btn);
(function(index) {btn.onclick = function() {document.getElementById(input_id).value += index;};})(i);
}
for (var j = 0; j < operators.length; j++) { // make buttons with operators
var btn = document.createElement ("button");
btn.innerHTML = operators[j];
btn.id = operators[j];
in_div.appendChild(btn);
if (operators[j] === "=") {
btn.onclick = function() {document.getElementById(input_id).value = eval(document.getElementById (input_id).value);};
}
else if (operators[j] === "c") {
btn.onclick = function() {document.getElementById(input_id).value = '';};
}
else if (operators[j] === "DEL") {
btn.onclick = function() {clearBox(div_id);};
}
else {
(function(index) {btn.onclick = function() {document.getElementById(input_id).value += index;};})(operators[j]);
}
};
};
function clearBox(elementID) // delete the selected instance of calc
{
document.getElementById(elementID).innerHTML='';
}
나는 아직도 그것을 얻지 못한다고 생각한다. 그래서 initPage에서 전체 onload 블록을 꺼내고 그 함수를 비워 둔다. 그런 다음 initc() 호출을 호출하는 첫 번째 행에 페이지를로드하도록 지시합니다. 변경 및로드? 그런데 어떻게 그렇게 말합니까? – Veske
나는 window.onload alltogether를 제거하고 그 안에있는 내용을 initPage에 넣었습니다. 이제 페이지를 처음로드 할 때 스크립트가로드되지만 페이지를 다시로드하면 스크립트가 두 배로 늘어납니다. 갑자기 2 개의 버튼이 있습니다. – Veske
블록 래퍼'window.onload = function() {});'을 꺼내고 다른 코드는 안에두면됩니다. 또한 jQuery의 문서를 사용할 준비가되었습니다 : window.on ('page : change', function() {initPage()}뿐만 아니라'$ (document) .ready (function() {initPage()}) }); –