在js中怎么样选择互斥的相邻元素
在使用jquery中,我们通常会选择siblings()去选择相邻元素,使用eq()方法去匹配元素,使用index()获取对应元素的索引值,具体jquery代码如下:
<style>
*{padding:0px;margin:0px;}
ul li{list-style:none;}
.box ul li{padding:10px 0px;}
.active{background:red;}
</style>
div class="box">
<ul>
<li class="active">1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
</div>
$(".box").find("li").on("click",function(){
<script type='text/javascript' src="jquery-1.11.2.min.js"></script>
<script type="text/javascript">
$(".box").find("li").on("click",function(){
var $index = $(this).index();//获取点击当前的索引
$(this).addClass("active").siblings("li").removeClass("active");//为当前点击元素添加class,移除相邻兄弟元素li的active
console.log($index);
});
var $li = $(".box li").eq(0);//获取第一li
console.log($li); </script>
从上以上jquery代码可以很简单的实现了相邻元素的匹配筛选以及获取当前点击的索引值,然而在js中获取索引以及筛选相邻元素是这样的:
(function(){
var boxDom = document.getElementsByClassName("box")[0];//获取class的一种方式
var ulDom = boxDom.getElementsByTagName("ul")[0];
var liDom = ulDom.getElementsByTagName("li");
for(var i=0;i<liDom.length;i++){
liDom.index = i;//当前的索引值,添加一个自定义索引,自定义属性值,index是每一个li上自定义的索引值
liDom[i].onclick = function(){
//for循环,先清除所有的样式,再添加当前需要的样式
for(var j=0;j<liDom.length;j++){
liDom[j].className = "";//所有的li清除样式,0 1 2
};
this.className = "active"//为当前点击的class添加样式
console.log(this.index);//对应每一个点击li获取当前的index索引,0,1,2
}
}
})()
在筛选相邻元素上还有一种思路是这样的:
var boxDom = document.getElementsByClassName("box")[0];//获取class的一种方式
var boxDom = document.getElementsByClassName("box")[0];//获取class的一种方式
var ulDom = boxDom.getElementsByTagName("ul")[0];
var liDom = ulDom.getElementsByTagName("li");
//初始化值
var oli = null,num=0;//oli是上一次的值,num是初始值
oli = liDom[num];
for(var i=0;i<liDom.length;i++){
liDom.index = i;//当前的索引值,添加一个自定义索引
liDom[i].onclick = function(){
oli.className = "";//将所有oli的class值清除
oli = this;//记录上一次的class
this.className = "active";//添加当前点击的class
}
}
通过以上代码我们可知,jquey中api方法无论是筛选元素还是选择相邻元素,都会比js要简单得多,但原生js一些思想以及这里涉及的一些自定义属性的使用还是很基础的,以上简单的两个场景在使用jquery中非常简单,但原生js原理的思想还是要根深蒂固,基础性的东西还是很重要的
在js中怎么样选择互斥的相邻元素的更多相关文章
- js中的选择排序和冒泡排序
var arr = [12,25,8,16,14]; console.log("排序前数组,",arr) //选择排序:第一轮,找出数组中最小的数,将第一项和最小的数互换位置.第二 ...
- JS中的数组,添加删除元素,判断是否存在一个值的方法总结
一.添加元素: 1:在最后添加,返回数组长度:arr.push(...); 2:在最前面添加,返回数组长度:arr.unshift(...); 3:在指定位置添加,没有返回值:arr[i] = xxx ...
- js中的children实时获取子元素
先看下面一个小例子的结果 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...
- JS中字符串拼装 单双引号的处理 字符转义
js中可能会用到动态追加元素,可能数据也是从后台传过来的,当然有两种思路, 1.在后台拼装好直接返回; 2.在前台js里面拼装, 如果拼装大量的html时可能单双引号就容易出问题;那么如何解决呢?最近 ...
- JS中表格的全选和删除要注意的问题
在项目开发中,由于刚刚开始做项目,我对js还不是很精通,所以在用js对表格的全选和删除中遇到了不少问题,后来通过查找资料解决了,之后总结了一下关于js表格的全选和删除出现的一些问题,希望能帮助到大家. ...
- JS中集合对象(Array、Map、Set)及类数组对象的使用与对比
原文地址 在使用js编程的时候,常常会用到集合对象,集合对象其实是一种泛型,在js中没有明确的规定其内元素的类型,但在强类型语言譬如Java中泛型强制要求指定类型. ES6引入了iterable类型, ...
- JS中集合对象(Array、Map、Set)及类数组对象的使用与对比(转载)
在使用js编程的时候,常常会用到集合对象,集合对象其实是一种泛型,在js中没有明确的规定其内元素的类型,但在强类型语言譬如Java中泛型强制要求指定类型. ES6引入了iterable类型,Array ...
- javascript中快速求数组的全部元素的相加之和
js中快速求数组的全部元素的相加之和: var arr = [1,2,3,4,5];var sum = eval(arr.join('+')); console.log(sum); 运行结果: 15
- Vue.js中使用select选择下拉框
在Vue.js中使用select选择下拉框有两种方法: 第一种: Add.html: <select v-model="sysNotice.noticeType" id=&q ...
随机推荐
- JSBinding / Plugins & Build Mozjswrap Library
There are 2 libraries in Plugins: mozjs-31. This is SpiderMonkey library, built from https://github. ...
- 10天学会phpWeChat——第三天:从数据库读取数据到视图
在第二天,我们创建了我们的第一个phpWeChat功能模块,但是比较简单.实际生产环境中,我们不可能有如此简单的需求.更多的情况是数据存储在MySql数据库中,我们开发功能模块的作用就是将这些数据从M ...
- SQLSERVER系统视图,系统表,sys.sql_modules视图
SQLServer中提供了相当丰富的系统视图,能够从宏观到微观,从静态到动态反应数据库对象的存储结果.系统性能.系统等待事件等等.同时 也保留了与早期版本兼容性的视图,主要差别在于SQLServer2 ...
- Java命名规范基础
一.java命名规范 1.类和接口:由多个单词组成时,所有单词的首字母大写,如TestJava 2.变量名和方法(函数):由多个单词组成时,所有第一个单词的首字母小写,之后每一个单词的首字母大写,如: ...
- k8s dashboard 部署发布
https://rawgit.com/kubernetes/dashboard/master/src/deploy/kubernetes-dashboard.yaml # Copyright 2015 ...
- 数据库服务器CPU持续百分之百、部分Session一直处于执行状态---等待事件为:asynch descriptor resize(Oracle Bug )
问题描述: 项目反馈数据库服务器的CPU持续100%的情况,跟踪发现很多活动会话的等待事件是“asynch descriptor resize”,并且这些会话一直处于Active状态,而这些会话执行的 ...
- java1234教程系列笔记 S1 Java SE chapter 02 lesson 03 java基本数据类型
第二章 第三节 数据类型 3.1 分类 基本数据类型.引用类型 3.2整型 byte 8 short 16 int 32 long 64 作业: A:1-10求和 B:float double 的最 ...
- DBMS_OUTPUT in SQL Developer
I fell sad for all the programmers(including) that has to SQL Developer as sql IDE. However, if you ...
- kali 初始化
关于kali使用前的一些配置,网上有很多版本,但是几乎都很雷同,或者是不全,或者是根本就没有测试过,或者是有的方法是错的(换句话说是版本变化的差异),因此让很多人接触kali时百度无数,效果一般,浪费 ...
- 解决ie6下不支持fix属性,模拟固定定位
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...