所有的操作都可以分为增、删、改、查四种,juery选择器代表查看的功能,那么剩下的操作就是对页面元素增、删、改。页面元素有3部分构成:标签,属性和内容,juery对元素的操作可以从这3方面入手。

一、juery对标签的操作


  • 新建元素

 //js创建元素
var ele_div = document.createElement("<div>")
//元素属性
//ele_div.setAttribute("id","demo");
var ele_attr = document.createAttribute("id")
ele_attr.nodeValue="demo"
ele_div.setAttributeNode(ele_attr);
//元素内容
//ele_div.innerHTML="hello world"
var ele_cont =document.createTextNode("hello world");
ele_div.appendChild(ele_cont);
 //juery创建元素
var demo = $("<div/>") //HTML字符串是没有属性的元素时,内部使用document.createElement_x创建元素 与$("<div>")相同
//var demo = $("<div id = 'demo' />"); //内部使用innerHTML创建元素
//元素属性
demo.prop("id","demo") //等同与attr()
//元素内容
demo.html("hello world")
  • 删除元素

 //js删除元素  (removeChild()只能删除其下一级元素)
//找到要刪除的元素
var demo = $("ul li")[2]
//找到其上級元素
document.getElementsByTagName("ul")[0].removeChild(demo)
//demo.parentNode.removeChild(demo)
//body 刪除所有节点 好像只能body使用 并且无法使用选择器选择的body对象执行这个方法
//document.body.removeNode()
//无法删除
//document.body.removeChild(demo)
 //juery删除元素
//删除元素
$("ul li:eq(0)").remove()
//删除被选元素的子元素
$("ul:eq(0)").empty();

二、juery对元素的操作


  • 新增和删除属性

 //基本的操作在上面介绍过了
var demo = $("ul li:eq(0)")[0] //1、新增自定义属性
demo.setAttribute("tkey","demo");
//删除属性
//demo.removeAttribute("tkey")
//demo.attributes.removeNamedItem("tkey") //两种方式效果相同
$("ul>li[tkey]").html("hello world") //2、操作css类 用getAttribute()和setAttribute()方法 要考虑浏览器兼容问题
demo.className="class_1 class_3"
//$("ul>li[class=class_1]").next().html("hello world")
$("ul>li[class*=class_1]").next().html("hello world")
//根据js对字符串操作来重新为className赋值 js中暂时没找到对应的方法
//增加一个className
demo.className = demo.className+" "+"class_2";
//更换className
demo.className = demo.className.replace("class_2","class_3")
//删除一个className
demo.className = demo.className.replace("class_3"," ")
document.getElementsByClassName("class_3")[0].innerHTML="class_1"
 //juery 操作元素属性
var ab={"id":"li_0","tkey":"demo"}
var demo = $("ul li:eq(0)")
demo.html("hello world")
//新增属性
demo.attr(ab)
//demo.attr("id","demo");
//删除属性
//demo.removeAttr("id") //1、操作css类
//新增class
demo.attr("class","class_1")
demo.addClass("class_2")
//删除class
demo.removeClass("class_4")
demo.removeClass()
//判断是否存在className
alert(demo.hasClass()) //开始未指定class和移除class时 为false
//含有判断的操作
demo.toggleClass("class_4") //存在就删除 不存在就增加
demo.toggleClass("class_4",false) //true 增加 false 删除 同addClass(name)和removeClass(name) 不同于removeClass()
//修改css样式
//demo.css("color:red")没有效果
//demo.css("color")= "red"
demo.css("color","red")
//没有找到juery 直接删除样式的例子,都是通过修改className来更换样式

三、juery对元素内容操作


元素内容为开始标签和结束标签之间的部分,里面可以只有文本也可以包含多个页面元素。

  • 新增

 //js插入数据
//准备操作对象
var demo = $("ul li:eq(0)").clone()
demo.html("hello world")
var dom_demo=demo[0]
var dom_ul = $("ul:eq(0)")[0];
//将node添加到childNodes的末尾
dom_ul.appendChild(dom_demo)
//在选择node后插入使用的是同一个对象的话 不会另外复制一份
dom_ul.insertBefore(dom_demo,document.getElementsByTagName("li")[1])
//没有这个方法
//dom_ul.insertAfter(dom_demo,document.getElementsByTagName("li")[1])
 //juery
//使用上面的对象
//插入数据
$("<li>hello world</li>").appendTo('#d_ul') //$(dom_ul) dom_ul 效果一样 说明appendTo(dom)内的内容会使用$(dom)转换成juery对象 如果$(dom)不是一个juery对象无法执行
$(dom_ul).append("<li>hello world</li>"); //效果同上 只不过参数位置不同
$("ul>li:eq(3)").after("<li>hello world</li>") //同insertAfter() 虽然资料上说insertAfter()接受的是juery对象 但是它会自动转换传入的对象
$("ul>li:eq(3)").before("<li>hello world</li>") //同insertBefore() 同上
  • 修改

 1 //js 替换子元素
2 var dom_ul = $("ul:eq(0)")[0]; //等同于 document.getElementByTagName("ul")[0]
3 var demo = $("<li>hello world</li>")[0]
4 dom_ul.replaceChild(demo,$("ul>li :eq(3)")[0])
5 document.replaceChild(demo,$("ul>li :eq(3)")[0]) //会替换掉ul中第4个元素
 //juery替换子元素
var dom_ul = $("ul:eq(0)"); //等同于 document.getElementByTagName("ul")[0]
var demo = $("<li>hello world</li>")
//demo.replaceWith(dom_ul.find("li:first-child")) //写反了
//将选择的内容替换成()中的内容 ()中的内容会 $()转换成juery对象 因此可以传入dom 字符串等可以解析成juery对象的参数
dom_ul.find("li:first-child").replaceWith(demo);
//dom_ul.replaceAll(demo) //又反了
//将选择的内容替换到括号内的选择器 传入参数类型同上
demo.replaceAll(dom_ul)

参考资料:

JS操作元素的属性和方法:http://weirhp.iteye.com/blog/963835

jquery插入方法汇总:http://blog.sina.com.cn/s/blog_700e11ff0101b2y2.html

juery学习总结(二)——juery操作页面元素的更多相关文章

  1. Selenium with Python 005 - 调用js操作页面元素

    WebDriver提供了execute_script()方法来执行JavaScript方法,格式如 driver.execute_script(script,*args) 执行js一般有两种场景,一是 ...

  2. 使用javaScript操作页面元素

    from selenium import webdriver import time import unittest from selenium.common.exceptions import We ...

  3. selenium常用命令--操作页面元素及获取元素内容整理

    selenium常用命令之操作页面元素及获取元素内容的事件整理 例子:  /**id <input type="text" id="phone" name ...

  4. [Selenium] 操作页面元素等待时间

    WebDriver 在操作页面元素等待时间时,提供2种等待方式:一个为显式等待,一个为隐式等待,其区别在于: 1)显式等待:明确地告诉 WebDriver 按照特定的条件进行等待,条件未达到就一直等待 ...

  5. F12修改html进行本地js操作页面元素

    F12修改html进行本地js操作页面元素

  6. Java&Selenium调用JS实现高亮被操作页面元素高亮

    Java&Selenium调用JS实现高亮被操作页面元素高亮 /* * the method of invoking js to do something * * @author daviey ...

  7. selenium webdriver学习(四)------------定位页面元素(转)

    selenium webdriver学习(四)------------定位页面元素 博客分类: Selenium-webdriver seleniumwebdriver定位页面元素findElemen ...

  8. 利用 jQuery 操作页面元素的方法,实现电商网站购物车页面商品数量的增加和减少操作,要求单项价格和总价随着数量的改变而改变

    查看本章节 查看作业目录 需求说明: 利用 jQuery 操作页面元素的方法,实现电商网站购物车页面商品数量的增加和减少操作,要求单项价格和总价随着数量的改变而改变 当用户单击"+" ...

  9. 使用 jQuery 操作页面元素的方法,实现浏览大图片的效果,在页面上插入一幅小图片,当鼠标悬停到小图片上时,在小图片的右侧出现与之相对应的大图片

    查看本章节 查看作业目录 需求说明: 使用 jQuery 操作页面元素的方法,实现浏览大图片的效果,在页面上插入一幅小图片,当鼠标悬停到小图片上时,在小图片的右侧出现与之相对应的大图片 实现思路: 在 ...

随机推荐

  1. Linux下安装 Posgresql 并设置基本参数

    在Linux下安装Postgresql有二进制格式安装和源码安装两种安装方式,这里用的是二进制格式安装.各个版本的Linux都内置了Postgresql,所以可直接通过命令行安装便可.本文用的是Cen ...

  2. WPF 自定义窗口

    在WPF中,经常需要对窗口进行设置,下面讲讲常用的几个设置. 1.无边框窗口 WindowStyle="None" 窗口样式无 AllowsTransparency="T ...

  3. VS 插件ReSharper10 破解注册方法(转)

    ReSharper 10.0.0.1 Ultimate 完美破解补丁使用方法,本资源来自互联网,感谢吾乐吧软件站的分享. ReSharper是一款由jetbrains开发的针对C#, VB.NET, ...

  4. LK产品如何提高通信速率

    之前做LK,由于采用自定义协议,485通信.为了避免通信撞车,采用主控轮询.从机应答的通信方式. 当设备规模扩大,需要轮询的子设备和参数变多时,轮询周期就会加长,人机交互时,系统反应缓慢. 分析主控轮 ...

  5. 数组,集合分割函数,join()

    join函数定义如下: // 串联类型为 System.String 的 System.Collections.Generic.IEnumerable<T> 构造集合的成员,其中在每个成员 ...

  6. JAVA设计模式之2-简单工厂模式

    今天来介绍简单工厂模式,工厂模式包括简单工厂模式和抽象工厂模式,今天先讲简单工厂模式,然后引申到抽象工厂模式 在没有工厂模式前,我们创建类是直接new一个对象,比如下面所示,北汽有两个小型SUV,分别 ...

  7. 关于AngularJS(1)

      在讲正题之前,先说一下有关angular简介方面的信息: 1. angularJS  诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀的前端JS框架,已经 ...

  8. setTimeout和setInterval从入门到精通

    我们在日常web前端开发中,经常需要用到定时器方法. 前端中的定时器方法是浏览器提供的,并不是ECMAScript规范中的.是window对象的方法. 浏览器中的定时器有两种, 一种是每间隔一定时间执 ...

  9. 修改Linux用户的UID、GID

    对于NFS共享文件,保留文件权限,需要UID.GID与nfs-server端一致! 试验环境:Centos6.5_64/172.24.0.26 01.用户的UID和GID不能被占用 [root@26 ...

  10. C#记录程序运行时间记录显示

    //引入命名空间            using System.Diagnostics;            //清空导入时间 lbImportTime.Text = ""; ...