JavaScript DOM 学习总结(五)

前端之家收集整理的这篇文章主要介绍了JavaScript DOM 学习总结(五)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

  当页面加载时,浏览器会创建页面的文档对象模型(Document Object Model)。文档对象模型定义访问和处理HTML文档的标准方法。DOM 将HTML文档呈现为带有元素、属性和文本的树结构,即节点树。通过DOM,JS可创建动态的HTML,可以使网页显示动态效果并实现与用户的交互功能。JS能够改变页面中所有的HTML元素、属性和CSS样式,并对页面中所有事件做出响应。所以学习JS的起点就是处理网页,处理网页就需要使用DOM进行操作。

2、DOM获取元素。

  JS要想操作HTML元素,那么首先就必须先找到该元素。通常使用以下几种方法完成:

  通过元素设置的id找到HTML元素。

  通过标签名找到HTML元素。

  通过元素设置的名称(name)找到HTML元素。

  所谓的DOM,实际上就是document,获取元素就是操作document。

  (1)、通过id找到元素

  方法:document.getElementById('id');

  网页是由标签将信息组合起来的,id属性值是唯一的,就像身份证一样,通过一个身份证可以找到相对应的人,所以通过该方法,可以获取到与之相对应的标签,而获取的元素在JS中是一个对象,若想对元素进行操作,则需要通过他的属性方法

  (2)、通过标签名找到元素

  方法:document.getElementsByTagName('Tagname');

  通过该方法,返回的是带有指定标签名的对象的集合,也就是以数组的形式返回,返回的顺序是他们在文档中的顺序。

  (3)、通过name找到元素

  方法:document.getElementsByName('name');

  该方法与getElementById()方法有点相似,都是通过设置的属性值找到元素,只不过该方法是通过设置的name属性值查找元素。name属性在文档中可能不唯一,所以该方法返回的也是元素的数组,而不是一个元素。

//获取所有name值为txt的元素 var oTxt=document.getElementsByName("txt"); //获取元素的个数 alert(oTxt.length); //返回: //获取第二个元素的值 alert(oTxt[].value); //返回:

  既然可以通过id找到元素,那么也就可以通过class找到元素。className属性用于设置或者返回元素的class类名。

  语法:object.className = 'className'

  该方法可以控制class类名,返回元素的class属性,作用是可以为网页中某个元素指定一个className来更改该元素的外观。

  实例:简单的网页换肤效果

<Meta charset="UTF-"> 网页换肤@H_<a href="/tag/404/" target="_blank" class="keywords">404</a>_58@ <style> body{ background:lightgreen; } .col{ background:lightgray; } .col{ background:lightblue; } .col{ background:violet; } .col{ background:pink; } .col{ background:#f; } </style> </head> <body id="boy"> 点击切换:<input type="button" value="灰色" onclick="gr()"> <input type="button" value="蓝色" onclick="bl()"> <input type="button" value="紫色" onclick="vi()"> <input type="button" value="粉色" onclick="pi()"> <input type="button" value="橘色" onclick="or()"> <script> var x = document.getElementById('boy'); function gr(){ x.className='col'; } function bl(){ x.className='col'; } function vi(){ x.className='col'; } function pi(){ x.className='col'; } function or(){ x.className='col'; } </script> </body> </html></pre> </div> <p>  这只是一个简单的切换背景色<a href="/tag/xiaoguo/" target="_blank" class="keywords">效果</a>,如果想切换网页的整体样式,可以使用外部CSS<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>,通过JS改变link<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>的href<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>来完成。</p> <p>  如果想设置多个class类名相同的元素的样式,就需要借助数组的<a href="/tag/fangfa/" target="_blank" class="keywords">方法</a>来完成,其实现原理也很简单,首先通过id<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>其父元素,再<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>父元素下所有子元素的<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>名,<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a><a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>名返回的是元素的数组,所以就可以和访问数组一样的<a href="/tag/fangfa/" target="_blank" class="keywords">方法</a>来访问元素的数组,那么先使用循环遍历该元素数组,再做判断,如果这个元素的className等于我们设置的class<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>值,就说明这是我们要找的元素。</p> <p>  实例:将有序列表中所有class<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>值为"col"的元素背景颜色设置为绿色。</p> <div class="jb51code"> <pre class="brush:js;"> <body> <ol id="o"> <li>热点</li> <li class="col">美食</li> <li>数码</li> <li class="col">科技</li> <li>社会</li> <li class="col">养生</li> </ol> <script> //通过id<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>父元素 var aOl = document.getElementById('o'); //通过<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>名<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>父元素下所有子元素 var oLi = aOl.getElementsByTagName('li'); //循环遍历返回的子元素数组 for(var i=;i<oLi.length;i++){ //如果当前子元素的className等于设置的class<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>值,则将其背景设置为绿色 if(oLi[i].className=='col') oLi[i].style.background='green'; } </script> </body></pre> </div> <p>  下面是一个通过class<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>值<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>元素的封装<a href="/tag/hanshu/" target="_blank" class="keywords">函数</a>,方便以后使用。</p> <div class="jb51code"> <pre class="brush:js;"> <!DOCTYPE html> <html> <head> <<a href="/tag/Meta/" target="_blank" class="keywords">Meta</a> charset="UTF-"> <title>封装getByClass<a href="/tag/hanshu/" target="_blank" class="keywords">函数</a>@H_<a href="/tag/404/" target="_blank" class="keywords">404</a>_58@ <script> //第一个参数为<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>的父元素,第二个参数为class<a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>值。 function getByClass(oParent,aClass){ //空数组可以把找到的所有className都存放在里边,最后返回。 var aResult=[]; //通过<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>名<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>父元素下所有子元素。<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>名不固定,所以设置为*,便于传入。 var aEle=oParent.getElementsByTagName('*'); //循环遍历返回的子元素数组 for(var i=;i<aEle.length;i++){ //如果当前子元素的className等于传入的class属性值,则将其添加到数值中。 if(aEle[i].className==aClass) aResult.push(aEle[i]); } //最后将这个数组返回 return aResult; } </script> </head> <body> <ol id="o"> <li>热点</li> <li class="col">美食</li> <li>数码</li> <li class="col">科技</li> <li>社会</li> <li class="col">养生</li> </ol> <script> //封装函数的使用: //先通过id获取父元素 var aOl=document.getElementById('o'); //再调用封装好的函数传入参数,获取的父元素,子元素的class属性值 var oCol=getByClass(aOl,'col'); //最后循环遍历,设置样式 for(var i=;i<oCol.length;i++){ oCol[i].style.background='green'; } </script> </body> </html></pre> </div> <p><span style="color: #0000ff"><h3>3、DOM操作。</h3></p> <p>  获取到HTML元素之后,就可以进行相应的操作。</p> <p>  (1)、改变HTML</p> <p>  修改HTML内容的最简单的方法时使用 innerHTML 属性。innerHTML顾名思义,inner就是内部的,既然是HTML,那么就可以给里边放HTML。该属性可用于获取和替换HTML元素的内容。</p> <p>  语法:document.getElementById(id).innerHTML = new HTML</p> <div class="jb51code"> <pre class="brush:js;"> <body> <h id="tit">原标题</h> <script> //改变原有标题 var aH=document.getElementById('tit'); aH.innerHTML='新标题'; </script> <div id="div" style="width:px;height:px;border:px solid black;"></div> <script> //创建HTML内容 var oDiv=document.getElementById('div'); oDiv.innerHTML='<h>我是h标题</h><p>我是一个段落</p>'; </script> </body></pre> </div> <p>  (2)、操作元素属性</p> <p>  修改元素属性最简单的方法就是直接修改,语法:document.getElementById(id).属性名 = new value 比如修改图片src属性的指向路径。</p> <p>  此外还可以通过DOM方法获取、添加、删除元素的属性。</p> <p>  ①、getAttribute()</p> <p>  getAttribute()方法通过元素节点的属性名获取属性的值。</p> <p>  语法:elementNode.getAttribute(name)  name是想要获取的元素节点的属性名</p> <p>  ②、setAttribute()</p> <p>  setAttribute()方法添加一个新属性并指定值,或者把一个现有的属性设定为指定的值。</p> <p>  语法:elementNode.setAttribute(name,value)  name是属性名,value是属性值。</p> <p>  ③、removeAttribute()</p> <p>  removeAttribute()方法可删除元素的属性。</p> <p>  语法:elementNode.removeAttribute(name)  name是属性名。</p> <div class="jb51code"> <pre class="brush:js;"> <!DOCTYPE html> <html> <head> <meta charset="UTF-"> <title>JavaScript实例 var oTxt=document.getElementById('txt'); var oBtn=document.getElementById('btn'); //获取按钮value属性的值 var a=oBtn.getAttribute('value'); alert(a); //返回:按钮 oBtn.onclick=function (){ //操作元素属性有三种方法: //第一种方法 //oTxt.value='请输入文字'; //第二种方法 //oTxt['value']='请输入文字'; //第三种方法 //修改文本框value属性的值 oTxt.setAttribute('value','请输入文字'); //删除按钮type属性 oBtn.removeAttribute('type'); //删除后默认为文本框 };

  (3)、改变CSS

  改变HTML元素的CSS样式可直接使用该语法:document.getElementById(id).style.样式名 = new style

JavaScript实例 HTML DOM
JS可以使网页添加动态效果并实现与用户交互的功能。

. JS能够改变页面中所有的 HTML 元素。

. JS能够改变页面中所有的 HTML 属性。

. JS能够改变页面中所有的 HTML 元素的CSS样式。

var oDiv = document.getElementById('div'); function color(){ oDiv.style.color = 'white'; oDiv.style.fontFamily = 'Microsoft YaHei'; oDiv.style.backgroundColor = 'green'; } function hig(){ oDiv.style.width = 'px'; oDiv.style.height = 'px'; oDiv.style.border = 'px solid #ccc'; } function none(){ oDiv.style.display = 'none'; } function block(){ oDiv.style.display = 'block'; } //取消设置 function cancel(){ var clean = confirm('确定取消所有设置?'); if(clean == true){ oDiv.removeAttribute('style'); } }

  上面的代码,通过style设置的样式,都是行间样式,可以使用火狐的Firebug点击相应的按钮,就能看到所有设置的CSS样式都出现在了行间。

  可以直接通过style获取和设置CSS样式,那么有没有更简洁的方法呢?可以借助于函数使用JS的内置对象arguments完成,所谓arguments,就是可变参,不定参,参数的个数可变,是一个参数数组,无需指出参数名,就可访问他们,但是为了增强可读性,给参数取名,还是很有必要的。

JavaScript实例

  下面是一个获取和设置行间样式的封装函数,以便以后使用。

获取行间样式

  我们都知道,在实际的WEB项目开发中,要遵循结果、表现、行为相分离的原则,以增强可读性,优化代码,便于后期维护。所以通常我们设置元素的样式,并非都是在行间设置。使用style方法获取的只是DOM元素style属性里的样式规则,对于通过class属性设置的外部样式表,style就显得力不从心了。那要如何获取元素的非行间样式呢?DOM标准中有个全局方法getComputedStyle,通过该方法可以获取当前对象的样式信息。比如:getComputedStyle(obj,false).paddingLeft,可以获取到对象的左内边距。这里需要注意:在获取元素的复合样式时,一定要使用精确的值,复合样式比如background、border,如果要获取元素的背景颜色,只使用background会出错,一定要写成backgroundColor。

  JS只能修改元素的行间样式,并不能修改获取到的非行间样式。那么很多人可能会产生疑问,既然可以获取到又不能修改,那还获取有什么用。其实获取非行间样式是非常有必要的,如果是外部样式表,样式都是密密麻麻一片英文的存在,不可能一个个去找,到底该元素设置的什么样子,再回头修改,那岂不是太浪费精力了,所以该方法就显得尤为重要,而且返回的值都是精确值,通过获取的非行间样式信息,也有利于更精细的修改元素的当前样式,这是多么美妙的一件事,直接使用style设置元素的行间样式,因为行间样式的优先级最高,所以就覆盖掉了非行间样式,其实也就相当于跟修改了非行间样式一样,只是显示在了行间,我们目的反着是已经达到了。

获取非行间样式

  (4)、对事件做出响应

  实例:全选和反选,输入对应的序号选中

JavaScript实例
. 音乐 输入-序号选择,每次只可以选择一项:

3、DOM节点。

  HTML文档可以说是由节点构成的集合,常见的DOM节点有三种,即元素节点、属性节点和文本节点。元素节点就是HTML标签,标签的属性就是属性节点,文本节点就是页面可以浏览的内容。

  在文档对象模型中,每一个节点都是一个对象,DOM节点有三个重要的属性:节点的名称,节点的值和节点的类型。

  (1)、nodeName:节点的名称

  nodeName属性返回节点的名称。元素节点的名称与标签名相同(大写),属性节点的名称是属性的名称,文本节点的名称永远都是#text,文档节点的名称永远都是#document。

  (2)、nodeValue:节点的值

  nodeValue属性返回节点的值。元素节点的值是undegined或null,属性节点的值是属性的值,文本节点的值是文本自身。

  (3)、nodeType:节点的类型

  nodeType属性返回节点的类型。以下是常见的节点类型:

  • JS
  • DOM

  JS中函数可以嵌套使用,有父函数有子函数,HTML标签也可以嵌套使用,那么就说明存在着各种不同的节点关系,比如父节点、子节点和兄弟节点。为了方便操作,DOM定义了一些节点的公共属性。

  (1)、子节点

  childNodes属性返回节点的子节点集合,可使用length属性返回子节点的数量,然后就可以和数组一样获取需要的信息。

  通过上面的代码,可以看到返回的是11。ul下明明只有5个li元素,怎么会返回11呢?其实是这么回事:

第个节点(元素节点) 第个节点(文本节点)
  • 第个节点(元素节点)
  • 第个节点(文本节点)
  • 第个节点(元素节点)
  • 第个节点(文本节点)
  • 第个节点(元素节点)
  • 第个节点(文本节点)
  • 第个节点(元素节点)
  • 第个节点(文本节点)

      因为通过childNodes属性返回的子节点集合,不仅包括元素节点,而且还包括文本节点,浏览会将标签之间的空白默认为文本节点,在空白处输入文字,会在浏览器显示。所以建议使用children属性,该属性只返回元素节点,不包括文本节点,并且不包括注释节点。

      我是个文本节点 我是span元素。

      上面的代码,ul下5个li元素,返回子节点个数为5。children属性要比childNodes属性好用太多了,只返回元素的子节点,还不包括孙子辈节点。

      (2)、首尾子节点

      firstElementChild属性返回children数组的第一个节点。

      语法:node.firstElementChild  该方法相当于:element.children[0]

      lastElementChild属性返回children数组的最后一个节点。

      语法:node.lastElementChild  该方法相对于:element.children[element.children.length-1]

    JS

    DOM
    jQuery

      (3)、父节点

      parentNode属性用于获取指定节点的父节点。注意:父节点只能有一个。通过使用两个获取父节点,可获取祖节点。

      实例:点击子节点,隐藏父节点

      offsetParent属性可返回一个元素用于定位的父级。

    JavaScript实例

      (3)、兄弟节点

      nextElementSibling属性返回同一树层级中某个节点之后紧跟的节点。

      语法:element.nextElementSibling  

      previousElementSibling属性返回同一树层级中某个节点之前紧跟的节点。

      语法:element.previousElementSibling

      等。

        实例:获取li元素节点的兄弟节点

    • HTML
    • CSS
    • JS

    4、DOM应用。

      DOM最实际的应用就是可以通过JS创建、插入和删除节点。

      (1)、创建节点

      createElement()方法可创建元素节点。

      语法:document.createElement(tagName)

      appendChild()方法可在指定节点的末尾插入一个新的子节点,每次都向末尾添加。

      语法:父级.appendChild(new node)

      实例:创建并添加li元素

    JavaScript实例

      (2)、插入节点

      insertBefore()方法可在已有的子节点前插入一个新的子节点。

      语法:父级.insertBefore(new node,node)  第一个参数为要插入的新子节点。第二个参数是原有节点,也就是在谁之前插入。

      实例:创建并添加li元素,每个新创建的li元素都插入到之前插入的li元素之前

    JavaScript实例

      (4)、删除节点

      removeChild()方法用于删除一个节点

      语法:父级.removeChild(node)  参数为要删除的子节点。

      实例:简单的表格添加和删除

    JavaScript实例 姓名:添加">
    员工表ID

      这个实例只能很简单的完成添加删除,并不对输入进行判断,如果想要做的完美,还需要做很多工作,可以对表格进行美化,设置背景色,鼠标移入高亮显示,鼠标移出恢复背景色,最关键的就是要对表单输入内容进行判断,以确保每次提交的信息都是有效信息,如果表格信息量大,还可以添加支持模糊搜素,多关键字搜索,以提高用户体验度,当然在实际的项目中,这样的情况几乎不会出现,但可以作为自己的实践,检验学习成果。

      (5)、替换节点和创建文本节点

      replaceChild()方法可用于替换元素节点。

      语法:node.replaceChild (new node,node)  第一个参数为用于替换的节点。第二个参数为原有节点。

      createTextNode()方法可创建新的文本节点,返回新创建的Text节点。

      语法:document.createTextNode(txt)

      这两种方法平时几乎用不到,但还是需要了解。

      实例:点击按钮将span标签替换为b标签。再创建一个文本节点插入到创建的p元素下,并设置className。

    <Meta charset="UTF-"> JavaScript实例@H_<a href="/tag/404/" target="_blank" class="keywords">404</a>_58@ <style> .p{ width:px; height:px; background-color:#ccc; } </style> </head> <body> <p>创建一个P<a href="/tag/biaoqian/" target="_blank" class="keywords">标签</a>,设置<span id="s">className</span><a href="/tag/shuxing/" target="_blank" class="keywords">属性</a>,创建文本节点。</p> <input type="button" value="点击替换" onclick="change()"> <script> function change(){ //<a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>span元素 var oS=document.getElementById('s'); //创建一个b元素 var newnode=document.createElement('b'); //要替换的文本节点 var txt = document.createTextNode('className'); //将文本节点插入到创建的b元素下 newnode.appendChild(txt); //在span元素的父级下将span元素替换成新创建的b元素 oS.parentNode.replaceChild(newnode,oS); } //创建一个p元素 var oP=document.createElement('p'); //设置className oP.className='p'; //创建文本节点 var txtNode=document.createTextNode('createTextNode用于创建文本节点!'); //将创建的文本节点插入到p元素下 oP.appendChild(txtNode); //再将p元素插入到父级body下 document.body.appendChild(oP); </script> </body> </html></pre> </div> <p>以上所述是编程之家小编给大家<a href="/tag/fenxiang/" target="_blank" class="keywords">分享</a>的关于JavaScript DOM 学习总结(五)的全部叙述,希望大家喜欢。</p></div> <div class="topcard-tags"><a href="/tag/javascriptdom/" class="tag_link" target="_blank">javascript_dom</a></div> <ul class="list-group"> <li class="list-group-item"><a href="/js/51540.html" title="js生成随机数的过程解析">上一篇:js生成随机数的过程解析</a><a href="/js/51525.html" title="JS截取字符串实例详解" class="text-muted pull-right">下一篇:JS截取字符串实例详解</a> </li> </ul> </div> </div> </div> <!-- row end --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-4605373693034661" data-ad-slot="9144498553"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script></div> </div> </div> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <div class="title"><h1>猜你在找的JavaScript相关文章</h1></div> <div class="list_con"> <a href="/js/997747.html" title="Javascript中的事件冒泡与捕获"><div class="title">Javascript中的事件冒泡与捕获</div> <div class="summary">事件冒泡和事件捕获 起因:今天在封装一个bind函数的时候,发现el.addEventListener函数支...</div> <time class="summary">作者:前端之家 时间:2021-02-22</time> </a> </div> <div class="list_con"> <a href="/js/997746.html" title="搞懂js中小数运算精度问题原因及解决办法"><img class="lazy" src="/images/np.jpg" data-original="/res/2021/02-22/19/e40e1eb184cb2a5d8c5f6c5e730d8e82.png" title="" width="160" height="90" style="float:right;margin-left:30px;display:none;" /><div class="title">搞懂js中小数运算精度问题原因及解决办法</div> <div class="summary">js小数运算会出现精度问题 js number类型 JS 数字类型只有number类型,number类型相当于其...</div> <time class="summary">作者:前端之家 时间:2021-02-22</time> </a> </div> <div class="list_con"> <a href="/js/997744.html" title="搞懂:前端跨域问题JS解决跨域问题VUE代理解决跨域问题原理"><div class="title">搞懂:前端跨域问题JS解决跨域问题VUE代理解决跨域问题原理</div> <div class="summary">什么是跨域 跨域 : 广义的跨域包含一下内容 : 1.资源跳转(链接跳转,重定向跳转,表单提...</div> <time class="summary">作者:前端之家 时间:2021-02-22</time> </a> </div> <div class="list_con"> <a href="/js/997743.html" title="前端对base64编码的理解,原生js实现字符base64编码"><div class="title">前端对base64编码的理解,原生js实现字符base64编码</div> <div class="summary">@ &quot;TOC&quot; 常见对base64的认知(不完全正确) 首先对base64常见的认知,也是...</div> <time class="summary">作者:前端之家 时间:2021-02-22</time> </a> </div> <div class="list_con"> <a href="/js/997742.html" title="搞懂:MVVM模型以及VUE中的数据绑定数据劫持发布订阅模式"><div class="title">搞懂:MVVM模型以及VUE中的数据绑定数据劫持发布订阅模式</div> <div class="summary">搞懂:MVVM模式和Vue中的MVVM模式 MVVM MVVM : 的缩写,说都能直接说出来 :模型, :视图...</div> <time class="summary">作者:前端之家 时间:2021-02-22</time> </a> </div> <div style="border-bottom: 1px solid #f4f4f4;margin-top:20px;"> <ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-fr-2o+fp-dx-wx" data-ad-client="ca-pub-4605373693034661" data-ad-slot="4561116489"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script> </div><div class="list_con"> <a href="/js/997318.html" title="js判断浏览器是否支持webGL"><div class="title">js判断浏览器是否支持webGL</div> <div class="summary">起因是我之前开发的网页,用到了three.js制作了一个3d的旋转球体效果。 在各种浏览器上运行...</div> <time class="summary">作者:前端之家 时间:2021-02-14</time> </a> </div> <div class="list_con"> <a href="/js/997317.html" title="js判断undefined和null"><div class="title">js判断undefined和null</div> <div class="summary">js判断undefined js判断null js判断null和undefined</div> <time class="summary">作者:前端之家 时间:2021-02-14</time> </a> </div> <div class="list_con"> <a href="/js/997316.html" title="将文字自动转为banner打印形式的工具"><div class="title">将文字自动转为banner打印形式的工具</div> <div class="summary">http://patorjk.com/software/taag/</div> <time class="summary">作者:前端之家 时间:2021-02-14</time> </a> </div> <div class="list_con"> <a href="/js/997315.html" title="聊一聊 bootstrap 的轮播图插件"><div class="title">聊一聊 bootstrap 的轮播图插件</div> <div class="summary">今天做工作的时候,轻车熟路的做完,又用到了bootstrap的轮播图,觉得有必要安利一下这个插...</div> <time class="summary">作者:前端之家 时间:2021-02-14</time> </a> </div> <div class="list_con"> <a href="/js/997314.html" title="js实现图片无缝循环跑马灯"><div class="title">js实现图片无缝循环跑马灯</div> <div class="summary">html 代码 css js代码 function mylsRunHorseLight() { if (mylsTimer != null) { clearIn...</div> <time class="summary">作者:前端之家 时间:2021-02-14</time> </a> </div> <div style="border-bottom: 1px solid #f4f4f4;margin-top:20px;"> <ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-fr-2o+fp-dx-wx" data-ad-client="ca-pub-4605373693034661" data-ad-slot="4561116489"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script> </div></div> </div> </div> </div> <!-- left end--> <!-- right --> <div class="col-sm-12 col-md-12 col-lg-3"> <!-- row --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <label class="main-content-label ">编程分类</label> <div class="cate mt-20"><a href="/html/" title="HTML">HTML</a><a href="/html5/" title="HTML5">HTML5</a><a href="/js/" title="JavaScript">JavaScript</a><a href="/css/" title="CSS">CSS</a><a href="/jquery/" title="jQuery">jQuery</a><a href="/bootstrap/" title="Bootstrap">Bootstrap</a><a href="/angularjs/" title="Angularjs">Angularjs</a><a href="/typescript/" title="TypeScript">TypeScript</a><a href="/vue/" title="Vue">Vue</a><a href="/dojo/" title="Dojo">Dojo</a><a href="/json/" title="Json">Json</a><a href="/electron/" title="Electron">Electron</a><a href="/nodejs/" title="Node.js">Node.js</a><a href="/extjs/" title="extjs">extjs</a><a href="/express/" title="Express ">Express </a><a href="/xml/" title="XML">XML</a><a href="/es6/" title="ES6">ES6</a><a href="/ajax/" title="Ajax">Ajax</a><a href="/flash/" title="Flash">Flash</a><a href="/unity/" title="Unity">Unity</a><a href="/react/" title="React">React</a><a href="/flex/" title="Flex">Flex</a><a href="/antdesign/" title="Ant Design">Ant Design</a><a href="/webfrontend/" title="Web前端">Web前端</a><a href="/weapp/" title="微信小程序">微信小程序</a><a href="/wxmp/" title="微信公众号">微信公众号</a><div class="clearfix"></div> </div> </div> </div> </div> <!-- row end --> <!-- row --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <!-- f2er-rightads --> <ins class="adsbygoogle" style="display:block" data-ad-client="ca-pub-4605373693034661" data-ad-slot="7756441254" data-ad-format="auto" data-full-width-responsive="true"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script> </div> </div> </div> <!-- row end --> <!-- row --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <label class="main-content-label ">最新文章</label> <ul class="n-list"><li><a href="/js/997747.html" title="Javascript中的事件冒泡与捕获" target="_blank">• Javascript中的事件冒泡与</a></li> <li><a href="/js/997746.html" title="搞懂js中小数运算精度问题原因及解决办法" target="_blank">• 搞懂js中小数运算精度问题</a></li> <li><a href="/js/997744.html" title="搞懂:前端跨域问题JS解决跨域问题VUE代理解决跨域问题原理" target="_blank">• 搞懂:前端跨域问题JS解决</a></li> <li><a href="/js/997743.html" title="前端对base64编码的理解,原生js实现字符base64编码" target="_blank">• 前端对base64编码的理解,</a></li> <li><a href="/js/997742.html" title="搞懂:MVVM模型以及VUE中的数据绑定数据劫持发布订阅模式" target="_blank">• 搞懂:MVVM模型以及VUE中的</a></li> <li><a href="/js/997493.html" title="js实现横向跑马灯效果" target="_blank">• js实现横向跑马灯效果</a></li> <li><a href="/js/997318.html" title="js判断浏览器是否支持webGL" target="_blank">• js判断浏览器是否支持webG</a></li> <li><a href="/js/997317.html" title="js判断undefined和null" target="_blank">• js判断undefined和null</a></li> <li><a href="/js/997316.html" title="将文字自动转为banner打印形式的工具" target="_blank">• 将文字自动转为banner打印</a></li> <li><a href="/js/997315.html" title="聊一聊 bootstrap 的轮播图插件" target="_blank">• 聊一聊 bootstrap 的轮播图</a></li> </ul> </div> </div> </div> <!-- row end --> <!-- row --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <label class="main-content-label ">热门标签 <span class="pull-right tx-12"> <a href="/all" target="_blank">更多 ►</a></span> </label> <div class="topcard-tags"><a href="/tag/guanbiyangao/" title="关闭广告" target="_blank">关闭广告</a><a href="/tag/danduheaders/" title="单独headers" target="_blank">单独headers</a><a href="/tag/fengzhuangdaima/" title="封装代码" target="_blank">封装代码</a><a href="/tag/tishicuowu/" title="提示错误" target="_blank">提示错误</a><a href="/tag/zhengshuzhengze/" title="整数正则" target="_blank">整数正则</a><a href="/tag/fei0kaitou/" title="非0开头" target="_blank">非0开头</a><a href="/tag/tiaoye/" title="跳页" target="_blank">跳页</a><a href="/tag/chuyema/" title="出页码" target="_blank">出页码</a><a href="/tag/antdtable/" title="antd table" target="_blank">antd table</a><a href="/tag/tishiURLweizhuce/" title="提示URL未注册" target="_blank">提示URL未注册</a><a href="/tag/gongzhonghaozhifu/" title="公众号支付" target="_blank">公众号支付</a><a href="/tag/vuehashmoshi/" title="vue hash模式" target="_blank">vue hash模式</a><a href="/tag/iSlider/" title="iSlider" target="_blank">iSlider</a><a href="/tag/chepaijianpan/" title="车牌键盘" target="_blank">车牌键盘</a><a href="/tag/xunhuantupian/" title="循环图片" target="_blank">循环图片</a><a href="/tag/echartsshuangzhexian/" title="echarts 双折线" target="_blank">echarts 双折</a><a href="/tag/zuoyoubuju/" title="左右布局" target="_blank">左右布局</a><a href="/tag/DllPlugin/" title="DllPlugin" target="_blank">DllPlugin</a><a href="/tag/duixiangchuangjian/" title="对象创建" target="_blank">对象创建</a><a href="/tag/daziyouxi/" title="打字游戏" target="_blank">打字游戏</a><a href="/tag/quanxuan/" title="圈选" target="_blank">圈选</a><a href="/tag/lianglan/" title="两栏" target="_blank">两栏</a><a href="/tag/yunhanshu/" title="云函数" target="_blank">云函数</a><a href="/tag/mengban/" title="蒙版" target="_blank">蒙版</a><a href="/tag/ES2020/" title="ES2020" target="_blank">ES2020</a><a href="/tag/chuchuang/" title="橱窗" target="_blank">橱窗</a><a href="/tag/wufenggundonglunbo/" title="无缝滚动轮播" target="_blank">无缝滚动轮播</a><a href="/tag/sekuaipengzhuang/" title="色块碰撞" target="_blank">色块碰撞</a><a href="/tag/zujianxiaohui/" title="组件销毁" target="_blank">组件销毁</a><a href="/tag/wendangcaozuo/" title="文档操作" target="_blank">文档操作</a></div> </div> </div> </div> <!-- row end --> <!-- row --> <div class="row row-sm"> <div class="col-sm-12 col-md-12 col-lg-12"> <div class="card"> <!-- f2er-rightads --> <ins class="adsbygoogle" style="display:block" data-ad-client="ca-pub-4605373693034661" data-ad-slot="7756441254" data-ad-format="auto" data-full-width-responsive="true"></ins> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script> </div> </div> </div> <!-- row end --> </div> <!-- right end --> </div> </div> <footer id="footer"> <div class="container"> <div class="row hidden-xs"> <dl class="col-sm-6 site-link"> <dt>最近更新</dt><dd><a href="/win11/1005328.html" title="小米手机重装系统价格多少?专业维修服务详解" target="_blank">· 小米手机重装系统价格多少?专业维修服务详解</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005327.html" title="手把手教你重装电脑系统,让你的电脑焕然一新!" target="_blank">· 手把手教你重装电脑系统,让你的电脑焕然一新!</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005326.html" title="教你一步步重装XP系统,让你的电脑重获新生" target="_blank">· 教你一步步重装XP系统,让你的电脑重获新生</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005325.html" title="从备份到上网:一步步教你重装电脑系统" target="_blank">· 从备份到上网:一步步教你重装电脑系统</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005324.html" title="Sony笔记本电脑一键重装系统详细图文教程" target="_blank">· Sony笔记本电脑一键重装系统详细图文教程</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005323.html" title="Lenovo笔记本重装系统超详细教程,小白也能轻松上手" target="_blank">· Lenovo笔记本重装系统超详细教程,小白也能轻松...</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005322.html" title="联想笔记本一键重装Win10系统详细教程" target="_blank">· 联想笔记本一键重装Win10系统详细教程</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005321.html" title="电脑系统故障无需愁,专业维修店帮你重装旧貌换新颜" target="_blank">· 电脑系统故障无需愁,专业维修店帮你重装旧貌换新...</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005320.html" title="联想笔记本一键重装Win10系统图文教程,小白也能轻松搞定!" target="_blank">· 联想笔记本一键重装Win10系统图文教程,小白也能...</a><span class="text-muted pull-right">02-05</span></dd> <dd><a href="/win11/1005319.html" title="笔记本重装系统图文教程:从光盘启动一步到位" target="_blank">· 笔记本重装系统图文教程:从光盘启动一步到位</a><span class="text-muted pull-right">02-05</span></dd> </dl> <dl class="col-sm-4 site-link"> <dt>好站推荐</dt><dd> <a href="https://www.runoob.com" title="菜鸟教程(www.runoob.com)提供了编程的基础技术教程, 介绍了HTML、CSS、Javascript、Python,Java,Ruby,C,PHP , MySQL等各种编程语言的基础知识。 同时本站中也提供了大量的在线实例,通过实例,您可以更好的学习编程。" target="_blank">菜鸟教程</a></dd><dd> <a href="https://www.jb51.cc" title="编程之家(www.jb51.cc)是成立于2017年面向全球中文开发者的技术内容分享平台。提供编程导航、编程问答、编程博文、编程百科、编程教程、编程工具、编程实例等开发者最需要的编程技术内容与开发工具支持,与你一起学习编程,相信编程改变未来!" target="_blank">编程之家</a></dd><dd> <a href="" title="前端之家 f2er.com 前端开发人员所需学习知识手册。" target="_blank">前端之家</a></dd></dl> <dl class="col-sm-2 site-link"> <dt>商务合作</dt> <dd><a target="_blank" href="http://wpa.qq.com/msgrd?v=3&uin=76874919&site=qq&menu=yes">联系我们</a></dd> </dl> </div> <div class="copyright"> Copyright © 2019 前端之家. 当前版本 V7.0.16<br> <span class="ml5">前端之家 版权所有 <a href="https://beian.miit.gov.cn/" target="_blank" rel="nofollow">闽ICP备13020303号-10</a></span> </div> </div> </footer> <script type="text/javascript" src="/js/base.js"></script> </body> </html>
    姓名 年龄 操作