zoukankan      html  css  js  c++  java
  • JavaScript选择器和节点操作

    感谢:链接(视频讲解很清晰)

    下文中讲解用到Chrome中的console调试台,如果不懂最好先看一下:链接

    JavaScript选择器

    作用:选取html中的标签等内容,最重要的还是为节点的操作(增删查改)做准备。

    常用选择器:

    1、id选择器(document.getElementById( );) 

    例如从下面的网页中找到 id='d0 ' 的标签:

    <body>
    	<div id="d0" class="div">这是一个div</div>
    	<script type="text/javascript">
    		var getDiv=document.getElementById('d0');
    		console.log('getdiv');
    	</script>
    </body>

    运行截图:(通过上面的函数直接就能把获取到的标签内容存入getDiv中)

    2、class选择器(getElementsByClassName();)

    实现和上面一样的例子,但由于id在整个html中只有一个但class不同,所以如果存在多个classname满足选择条件会将他们存入一个数组中。

    例如:

    <body>
    	<div id="d0" class="div">这是一个div0</div>
    	<div id="d1" class="div">这是一个div1</div>
    	<div id="d2" class="div">这是一个div2</div>
    	<div id="d3" class="div">这是一个div3</div>
    	<script type="text/javascript">
    		var getDiv=document.getElementsByClassName('div');
    		console.log(getDiv);
    	</script>
    </body>

    运行截图:(把数组展开如下)

    也可以给getdiv加下标来获取特定的标签:

    3、其它选择器(document.querySelector();document.querySelectorAll();)

    注:该选择器兼容性差,但操作简单便于实现。

    红框中的内容说明这个选择器的括号中要加的是css选择器,即:如果要选id就用'#', class就用' . ' 。

    运行截图:

    节点操作:

    上面讲解的js选择器就是在给节点操作做准备,因为只有先找到该节点才能操作。

    1、查找:

    就不需要说了,上面js选择器的作用就是这个。

    2、增加:(document.createElement();)

    <body>
    	<div id="d0" class="div">这是一个div0</div>
    	<script type="text/javascript">
    		var p=document.createElement('p');
    		p.innerHTML="这是一个p标签";
    	</script>
    </body>

    但运行之后div标签没变化,为什么? 

    因为这个函数只是先申请一个p ,就算要加上p标签他也不知道往哪加,所以还需要一个函数(*.appendChild(p);) , 其中*代表js选择器选择的要增加的位置

    <body>
    	<div id="d0" class="div">这是一个div0</div>
    	<script type="text/javascript">
    		var p=document.createElement('p');
    		var getDiv=document.getElementById('d0');
                    //若通过class属性获得了位置不唯一,会报错,因为appendChild函数只能给一个标签添加子标签   
    		p.innerHTML="这是一个p标签";
    		getDiv.appendChild(p);
    	</script>
    </body>

    运行截图:(可以看到div下多了个p标签) 

    3、删除:

    函数:*1.removeChild(*2);其中*1,*2为父子关系的两个标签

    <body>
    	<div id="d0" class="div">
    		<p id='p0'>这是一个p标签</p>
    	</div>
    	<script type="text/javascript">
    		var getDiv=document.getElementById('d0');
    		var getP=document.getElementById('p0');
    		getDiv.removeChild(getP);
    	</script>
    </body>

    运行截图:

    4、修改(运用最广泛的一种节点操作)

    a.与css中的style相关的修改:

    <body>
    	<div id="d0" class="div">
    		<p id='p0'>这是一个p标签</p>
    	</div>
    	<script type="text/javascript">
    		var getDiv=document.getElementById('d0');
    		getDiv.style.backgroundColor='red';
                    //注意与css中的style:background-color: red;的区别
    		getDiv.style.color='purple';
    	</script>
    </body>

    运行截图: 

     

    b.修改id或修改classname:

    <body>
    	<div id="d0" class="div">
    		<p id='p0'>这是一个p标签</p>
    	</div>
    	<script type="text/javascript">
    		var getDiv=document.getElementById('d0');
    	        getDiv.id='ddd';
    	</script>
    </body>

    修改成功:(classname同理)

  • 相关阅读:
    VUE处理项目中的ESLint语法报错问题
    通过Focas连接Fanuc的NC Guide
    IdentityServer
    Dapper2.0.78手册翻译
    Framework项目持续集成(jenkins)及集合SonarQube
    基于 GitBook 搭建个人博客
    GitBook 常用插件
    Vue管理系统前端系列六动态路由-权限管理实现
    Vue管理系统前端系列五自定义主题
    Vue管理系统前端系列四组件拆分封装
  • 原文地址:https://www.cnblogs.com/ldu-xingjiahui/p/12594054.html
Copyright © 2011-2022 走看看