javascript中通过className灵活查找元素 例如我们要把根据class来进行修改样式

原文:javascript中通过className灵活查找元素 例如我们要把根据class来进行修改样式

一、背景:一个表单中,要修改一些li中有class=box的样式,将它的background设置为red红色。一般的做法是我们可以先找到父级元素 ,然后由父级元素找到所有相关tagName,最后,来一个if判断,如果class属性为box,则修改之

 var oUl = document.getElementById("ul1");                                  //加上它的上级元素,可以避免我们筛选出许多无用的节点出来
var aLi = oUl.getElementsByTagName("li");

html代码:

 <ul id="ul1">
           <li class="box"></li>
           <li></li>
           <li class="box"></li>
           <li></li>
           <li class="box"></li>
 </ul>

 

一般做法的代码:

     <script>
              var oUl = document.getElementById("ul1");        //加上它的上级元素,可以避免我们筛选出许多无用的节点出来
              var aLi = oUl.getElementsByTagName("li");
              var i = 0;

              for(i =0; aLi.length; i++){
                     if(aLi[i].className == "box"){
                            aLi[i].style.background = "#FF9900";
                     }
              }
       </script>

 

为了代码重用,将其封装成一个小函数,存入代码库,以便以后可以使用。思路:查找className需要两个参数,一个数父级元素、一个是指定的class。通过父级元素,可以找到父级元素下的所有元素节点,有了这些元素节点呢,我们就可以获取到父级元素下的所有元素,最后通过if判断,并结合循环,把这些元素的class是指定值的遍历出来。通过className灵活查找元素    函数封装版
<!--
           作者:1107989194@qq.com
           时间:2014-04-13
           描述:通过className灵活查找元素    函数封装版
       -->
       <script>
              function getByClass(oParent,sClass){
                     var aEle = oParent.getElementsByTagName('*');      //获取父级元素下的所有元素
                     var aResult = new Array();
                     for(var i =0; i<aEle.length; i++){
                           if(aEle[i].className == sClass){
                               aResult.push(aEle[i]);
                           }
                     }
                     return aResult;
              }

              window.onload = function(){
                  var oUl = document.getElementById('ul1');
                  var aBox = getByClass(oUl,'box');
                  //获取到所有的class=box的属性后,进行修改 你想要的样式
                  for(var i =0; i<aBox.length; i++){
                         aBox[i].style.background = 'red';

                  }
              }

       </script>

 

时间: 2024-10-26 11:57:50

javascript中通过className灵活查找元素 例如我们要把根据class来进行修改样式的相关文章

javascript中通过索引访问数组元素的问题

问题描述 javascript中通过索引访问数组元素的问题 我想编写如下程序: 1.定义一个包含26个小写字母的数组 2.请用户输入0-25之间的自然数 3.alert对话框显示输入自然数作为索引对应的字母 代码如下: <script> //定义一个数组,包含了26个字母 var alphabet=[a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z]; //用户输入0-25之间的数字,并赋值给变量i var i=prompt("请

java中如何在LinkedList查找元素

LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用. LinkedList的构造函数如下 1. public LinkedList():  --生成空的链表 2. public LinkedList(Collection col):  复制构造函数 我们可以使用LinkedList的indexOf()或者lastIndexOf()方法来查找元素(遇到第一个匹配的元素即停止搜索,同时返回该元素的索引.所以,当LinkedList中有两个同样的元素的时候,使用这两个

javascript中为某个元素指定事件的三种方式_javascript技巧

在javascript中,可以为某个元素指定事件,指定的方式有以下三种: 1.在html中,使用onclick属性 2.在javascript中,使用onclick属性 3.在javascipt中,使用addEvenListener()方法 三种方法的比较 (1)在第二.三种方法中,可以向函数传入一个event对象,并读取其相应属性,而方法一不可以. (2)首选第二.三种,第一种不利于将内容与事件分离,也不能使用event对象的相关内容. 一些语法细节 (1)在第一种方法中,onclick大小写

javascript中Array()数组函数详解_javascript技巧

在程序语言中数组的重要性不言而喻,JavaScript中数组也是最常使用的对象之一,数组是值的有序集合,由于弱类型的原因,JavaScript中数组十分灵活.强大,不像是Java等强类型高级语言数组只能存放同一类型或其子类型元素,JavaScript在同一个数组中可以存放多种类型的元素,而且是长度也是可以动态调整的,可以随着数据增加或减少自动对数组长度做更改. Array()是一个用来构建数组的内建构造器函数.数组主要由如下三种创建方式: array = new Array() array =

javascript基础之查找元素的详细介绍

当然这些选择器都是jQuery扩展的一些方法,那么使用原生js时要怎样来查找元素呢?今天就来简单梳理下. DOM定义了多种查找元素的方法,除了我们常用的getElementById(),还有getElementsByTagName()和getElementsByName().使用这几种方法方法我们可以查找html文档中的任意html元素.getElementById()首先来看下getElementById(),这个方法很简单,只需在参数中传入html标签的id属性值即可,由于html页面中的i

javascript基础之查找元素的详细介绍(访问节点)_基础知识

当然这些选择器都是jQuery扩展的一些方法,那么使用原生js时要怎样来查找元素呢?今天就来简单梳理下. DOM定义了多种查找元素的方法,除了我们常用的getElementById(),还有getElementsByTagName()和getElementsByName().使用这几种方法方法我们可以查找html文档中的任意html元素.getElementById()首先来看下getElementById(),这个方法很简单,只需在参数中传入html标签的id属性值即可,由于html页面中的i

javascript中获取元素标签中间的内容的实现方法_javascript技巧

使用ajax,通过会把服务器端响应获取到reponseText或者reponseXML中的信息,以某种方法动态的写到div和span标记中,这样,可以在无刷新的情况下,改变页面内容的显示. 通过javascript进行动态的修改,修改的方法有两种: 1. 一种是使用html的每个标记的innerHTML属性,使用此属性,只要为它提供一个有意义的html代码片段,那么html解释器就可以将其中的内容进行解释,并显示在页面上,使用这种方式比较简单,每次修改前不需要先把原来的内容清除掉,而可以直接进行

javascript通过className来获取元素的简单示例代码

 本篇文章主要是对javascript通过className来获取元素的简单示例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助 示例如下:    代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="

剑指offer系列之三:在二维数组中查找元素

题目描述: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 由于题目条件的成立,所以使得这道题可以使用对角线的方法完成,可以从右上角的元素考虑,如果目标查找元素小于右上角的元素,那么不可能在右上角元素所在的列,如果目标大于剩余列的右上角的元素,那么不可能在该右上角元素所在的行.依照这个规律,就可以完成目标元素的查找(参考剑指offer书中的思路).基于此,我写出如下的代码(已被