详解jQuery中的元素的属性和相关操作


Posted in Javascript onAugust 14, 2015

元素属性

元素的属性中可以包含很多有用的信息,所以如何设置或得到属性中的值,就显得非常重要。

jQuery 的 $.fn.attr 方法可以作为 setter 和 getter 使用,用来设置或获取属性的值。和 $.fn.css 用法类似,$.fn.attr 既可一次性接受单个属性,也可以接受多个属性(对象) :

$('a').attr('href', 'allMyHrefsAreTheSameNow.html');
$('a').attr({
  'title' : 'all titles are the same too!',
  'href' : 'somethingNew.html'
});

上面代码中写对象的时候写成多行了,更具可读性。

$('a').attr('href'); // 返回选择其中第一个超链接的链接地址

一旦选择器的结果集中有元素了,就可以这些元素为基准点遍历其它元素了。关于 jQuery 遍历元素的方法,详见 http://api.jquery.com/category/traversing/,如:

$('h1').next('p');
$('div:visible').parent();
$('input[name=first_name]').closest('form');
$('#myList').children();
$('li.selected').siblings();

还可以用 $.fn.each 方法,对结果集中的元素一个一个处理:

$('#myList li').each(function(idx, el) {
  console.log(
    'Element ' + idx +
    'has the following html: ' +
    $(el).html()
  );
});

移动、复制、删除元素

如果要移动一个元素的位置:

// 把第一个列表移至最后
var $li = $('#myList li:first').appendTo('#myList');

// 另外一种方法,也能达到同样效果
$('#myList').append($('#myList li:first'));

复制一个元素

// 把第一个 li 做一份拷贝,然后放置列表的最后
$('#myList li:first').clone().appendTo('#myList');

如果复制元素的时候,想把元素的属性和事件等信息也一起复制了的话,调用 $.fn.clone 的时候给个参数 true 就 OK 了。

再说删除元素,jQuery 中各有两种方法可以删除元素:$.fn.remove 和 $.fn.detach,这两个方法都可以从页面中删除元素,并且这两种方法的返回值都是被删除的元素,区别是 $.fn.remove 的返回的元素中的不再包含元素的一些附属信息,如 id 和 class 等信息,也不包括元素上绑定的事件。$.fn.detach 则不同,将被删除元素中的附属信息和事件也一并保存了下来,具体是用哪种,要看实际需求了。
创建新元素

jQuery 可以很快捷的换件新元素:

$('<p>这是一个新段落</p>');
$('<li class="new">新列表元素</li>');

$('<a/>', {
  html : '这是一个 <strong>新</strong> 超链接',
  'class' : 'new',
  href : 'foo.html'
});

注意上面传入的 JavaScript 对象,里面的第二个属性 class 被加了引号,因为 class 是 JavaScript 的保留字,html 和 href 不是,所以不需要加引号。

创建新元素后,新元素并不会自动加入到页面中。加入页面中的话,可以用下面的方法:

var $myNewElement = $('<p>New element</p>');
$myNewElement.appendTo('#content');

$myNewElement.insertAfter('ul:last'); // 此操作会把 p 元素从 #content 中移除
$('ul').last().after($myNewElement.clone()); // 当然也可以克隆一个出来,现在 #content 中有两个 p 了哦

严格来说,不是一定要将新创建的元素保存在一个变量中,可以在创建后直接加入页面内。但是很多时候新创建的元素都要被多次使用,所以要缓存在一个变量中,这样不用重复去创建它了。

你甚至可以在向页面添加元素时创建它,但是这种情况下无法获得新创建元素的引用:

$('ul').append('<li>list item</li>');

往页面中添加新元素非常简单,但是如果需要向页面新加很多很多个元素的话,可能会有性能问题。因为每次向页面中添加元素,整个页面的 HTML 都要作为字符串参与拼接,这是非常耗费性能的。这种情况下,通常有以下处理方法:

var myItems = [], $myList = $('#myList');

for (var i=0; i<100; i++) {
  myItems.push('<li>item ' + i + '</li>');
}

$myList.append(myItems.join(''));
Javascript 相关文章推荐
Mootools 1.2教程 定时器和哈希简介
Sep 15 Javascript
js 模拟气泡屏保效果代码
Jul 10 Javascript
jquery ajax方式直接提交整个表单核心代码
Aug 15 Javascript
Javasipt:操作radio标签详解
Dec 30 Javascript
JavaScript使用位运算符判断奇数和偶数的方法
Jun 01 Javascript
JQuery的Pager分页器实现代码
May 03 Javascript
懒加载实现的分页&amp;&amp;网站footer自适应
Dec 21 Javascript
BootStrap 图片样式、辅助类样式和CSS组件的实例详解
Jan 20 Javascript
Vue.js 2.0 移动端拍照压缩图片预览及上传实例
Apr 27 Javascript
JS简单添加元素新节点的方法示例
Feb 10 Javascript
vue-cli中vue本地实现跨域调试接口
Jan 16 Javascript
小程序实现点击tab切换左右滑动
Nov 16 Javascript
js实现人才网站职位选择功能的方法
Aug 14 #Javascript
jQuery入门基础知识学习指南
Aug 14 #Javascript
Jquery全选与反选点击执行一次的解决方案
Aug 14 #Javascript
js实现Select列表各项上移和下移的方法
Aug 14 #Javascript
innerHTML中标签可以换行的方法汇总
Aug 14 #Javascript
jQuery编程中的一些核心方法简介
Aug 14 #Javascript
CSS图片响应式 垂直水平居中
Aug 14 #Javascript
You might like
追忆往昔!浅谈收音机的百年发展历史
2021/03/01 无线电
CentOS 6.2使用yum安装LAMP以及phpMyadmin详解
2013/06/17 PHP
php Calender(日历)代码分享
2014/01/03 PHP
jQuery中的RadioButton,input,CheckBox取值赋值实现代码
2014/02/18 PHP
一个非常完美的读写ini格式的PHP配置类分享
2015/02/12 PHP
php实现每天自动变换随机问候语的方法
2015/05/12 PHP
php类自动加载器实现方法
2015/07/28 PHP
是 WordPress 让 PHP 更流行了 而不是框架
2016/02/03 PHP
ThinkPHP自定义Redis处理SESSION的实现方法
2016/05/16 PHP
PHP实现的曲线统计图表示例
2016/11/10 PHP
yii 2.0中表单小部件的使用方法示例
2017/05/23 PHP
安装PHP扩展时解压官方 tgz 文件后没有configure文件无法进行配置编译的问题
2020/08/26 PHP
JS获取几种URL地址的方法小结
2014/02/26 Javascript
如何用jQuery实现ASP.NET GridView折叠伸展效果
2015/09/26 Javascript
JavaScript的this关键字的理解
2016/06/18 Javascript
AngularJs验证重复密码的方法(两种)
2016/11/25 Javascript
JS实现页面打印功能
2017/03/16 Javascript
详解Node.js access_token的获取、存储及更新
2017/06/20 Javascript
浅谈Vue 初始化性能优化
2017/08/31 Javascript
解决vue-router中的query动态传参问题
2018/03/20 Javascript
Vue项目移动端滚动穿透问题的实现
2020/05/19 Javascript
在vue中实现echarts随窗体变化
2020/07/27 Javascript
[41:08]2014 DOTA2国际邀请赛中国区预选赛 HGT VS NE
2014/05/22 DOTA
DataFrame 将某列数据转为数组的方法
2018/04/13 Python
Python爬虫 urllib2的使用方法详解
2019/09/23 Python
Python注释、分支结构、循环结构、伪“选择结构”用法实例分析
2020/01/09 Python
Keras-多输入多输出实例(多任务)
2020/06/22 Python
详解python方法之绑定方法与非绑定方法
2020/08/17 Python
C/C++程序员常见面试题一
2012/12/08 面试题
营销总监岗位职责范本
2014/02/26 职场文书
事业单位考核材料
2014/05/21 职场文书
小学生十佳少年事迹材料
2014/08/20 职场文书
2015年机械设备管理工作总结
2015/05/04 职场文书
学校2015年纠风工作总结
2015/05/15 职场文书
常用的MongoDB查询语句的示例代码
2021/07/25 MongoDB
Mysql将字符串按照指定字符分割的正确方法
2022/05/30 MySQL