このコード ウィッチは、数字の 1 を星に変更するのにうまく機能しますが、1 ~ 5 のようないくつかの数字を同じ数の星 (*) に変更したい場合は、同じループ内でこれを行うか、番号ごとに 1 つずつ、5 つの異なるループを作成する必要がありますか?
function changeNumber()
{
var elements= document.getElementsByClassName("grade");
for (var i=0; i<elements.length; i++) {
var element = elements[i];
var text = element.innerHTML;
var x = text.replace('1','*');
element.innerHTML=x;
}
}
このコードは、ユーザーが入力した値を取得し、配列に配置します...
var button = $('#add');
button.click(function()
{
//funktion för vad som ska hända när man klickar på knappen
var filmnamn = $('#name');
var filmnamnet = filmnamn.val();
var betyg = $('#star');
var betyget = betyg.val();
betyget = Number(betyget);
if(filmnamnet == 0)
{
$('#name').css('background-color', 'red');
}
if(betyget == 0)
{
$('#star').css('background-color', 'red');
}
if(betyget == 0 || filmnamnet == 0)
{
alert("Vänligen fyll i fälten korrekt");
}
else
{
var array = new Array();
array.unshift(betyget);
array.unshift(filmnamnet);
film_array.unshift(array);
betyg_array.unshift(array);
updateFilmList();
}
});
次に、関数 updateFilmlist は次のようになります...
var film_list = $("#filmlista");
var film_array = new Array();
function updateFilmList()
{
document.getElementById("name").value = '';
document.getElementById("star").value = 0;
var filmen = film_array[0][0];
var grade = film_array[0][1];
var element = '<li class="lista">' + filmen + '<span class="betyg">'+ grade +'</span></li>';
film_list.append(element);
changeNumber();
}
そして、あなたが私に見せてくれたコードをchangeNumber関数に追加したとき、スターに変更される唯一の数字は、動的に作成されたリストの最初のリスト要素です...その後、残りは数字として表示されます。なぜですか? ところで、betyg_arrayは別の関数用であり、問題とは何の関係もないので無視できます...