一个页面多次出现getElementById和getElementsByName导致起冲突效果不出现怎么决解?
例如:
<div id="a">
<div name="b">
<a href="{$v['url']}"><img src="{$v['litpic']}" />a>
div>
div>
<script type="text/javascript">
window.onload=function(){
randomFun()
}
function randomFun(){
var span=document.getElementById('a');
var spanItem=document.getElementsByName('b');
var random=function(){return Math.random()>0.5 ? -1 : 1};//为sort()传入的随机排列参数
var spanArr=new Array();//用来存放元素的数组
var k,m;
for(var i=0; ilength ; i++){
spanArr.push(spanItem[i]);//将元素存入元素数组
}
spanArr.sort(random);//打乱元素数组排列顺序
for(k=0; klength; k++){
span.appendChild(spanArr[k]);//将打乱后的元素重新插入到页面中
}
}
这是一个地方需要出现的效果几个地方同样也用到了getElementById和getElementsByTagName由于一个页面多次出现这两个导致只有最后用到的那个地方出现了效果,请问这个怎么决解?
基于Monster 组和GPT的调写:
将 id 改为类名(class),然后使用 getElementsByClassName 方法来选择元素\
<div class="a">
<div class="b">
<a href="{$v['url']}"><img src="{$v['litpic']}" /></a>
</div>
</div>
<script type="text/javascript">
window.onload=function(){
randomFun();
}
function randomFun(){
var container = document.querySelector('.a');
var itemArr = container.querySelectorAll('.b');
var random = function(){return Math.random()>0.5 ? -1 : 1};
var itemArrShuffled = Array.from(itemArr).sort(random);
itemArrShuffled.forEach(function(item){
container.appendChild(item);
});
}
</script>
用了 querySelector 和 querySelectorAll 方法来选择元素,这两个方法都可以使用类名、标签名等选择器来选择元素。然后将随机排序后的子元素插入到容器中。注意,这里使用了 Array.from 将 NodeList 转换为数组,以便使用数组的 sort 方法来排序。
不知道你这个问题是否已经解决, 如果还没有解决的话: