一、jquery各版本变化

1.3:增加live(),为当前和将来增加的元素绑定事件

1.4:增加delegate()、undelegate(),替代live(),可以遍历绑定

1.6:2个破坏性变更:data()返回值以驼峰形式展示,用attr()和prop()区分attribute和properties状态获取,attr()取不到动态改变的值了

1.6.1:调整attr(),兼容1.6以前的做法

1.7:增加on()、off(),替代bind()、delegate()、live()、unbind()、undelegate()和die(),更好的支持ie 6/7/8的html5

2.x:不再支持ie 6/7/8,内核调整

3.x:移除load()、unload()和error()

二、表单操作

1、复选框

全选

$('[name=items]:checkbox').prop('checked', true);

全不选

$('[name=items]:checkbox').prop('checked', false);

反选

$('[name=items]:checkbox').each(function() {
this.checked = !this.checked;
});

判断某项是否选中

$('[name=items][value=233]:checkbox').prop('checked')

获取所有选中的,用逗号分隔

$('[name=items]:checkbox:checked').map(function() {return $(this).val()}).get().join(',')

设置选中

var map = '2,4';
if(map != '') {
$.each(map.split(','), function(i, v) {
$('[name=items][value=' + v + ']:checkbox').prop('checked', true);
});
}

状态改变事件

$('[name=items]:checkbox').on('change', function() {
$('[name=items]:checkbox:checked').map(function() {return $(this).val()}).get().join(',');
});

2、单选框

全不选

$('[name=items]:radio').prop('checked', false);

判断某项是否选中

$('[name=items][value=233]:radio').prop('checked')

获取选中的

$('[name=items]:radio:checked').val()

设置选中

$('[name=items][value=' + 233 + ']:radio').prop('checked', true);

状态改变事件

$('[name=items]:radio').on('change', function() {
$(this).val();
});

3、下拉框

获取选中

$('select').val()

获取选中text

$('select').find('option:selected').text();

设置选中

$('select').val(233);

设置text选中

$('select').find('option[text=xxx]').prop('selected', true);

选中第一个

$('select').prop('selectedIndex', 0);

状态改变事件

$('select').on('change', function() {
$(this).find(':selected').val();
});

三、ajax操作

1、$.load()

$('#abc').load(url, [data], [callback]); //无论成功失败都会执行回调函数
$('#abc').load('def.html', {aaa: $('#aaa').val(), bbb: 'bbb'}, function(responseText, textStatus, XMLHttpRequest) {
//responseText: 请求返回的内容
//textStatus: 请求状态,success、error、notmodified、timeout
//XMLHttpRequest: XMLHttpRequest对象
});
无参数是get方式,有参数是post方式

2、$.get()

$('#abc').get(url, [data], [callback], [type]); //当Response的返回状态是success才执行回调函数
$('#abc').get('def.do', {aaa: $('#aaa').val(), bbb: 'bbb'}, function(data, textStatus) {
//data: 返回的内容,xml、json、html
//textStatus: 请求状态,success、error、notmodified、timeout
}, 'json');
url长度不要大于2kb
get的数据更容易被用户查看到

3、$.post()

$('#abc').post(url, [data], [callback], [type]); //当Response的返回状态是success才执行回调函数
$('#abc').post('def.do', {aaa: $('#aaa').val(), bbb: 'bbb'}, function(data, textStatus) {
//data: 返回的内容,xml、json、html
//textStatus: 请求状态,success、error、notmodified、timeout
}, 'json');

4、$.getJSON()

$('#abc').getJSON(url, [data], [callback]); //当Response的返回状态是success才执行回调函数
$('#abc').getJSON('def.do', {aaa: $('#aaa').val(), bbb: 'bbb'}, function(data, textStatus) {
//data: 返回的内容,xml、json、html
//textStatus: 请求状态,success、error、notmodified、timeout
});
getJSON还支持JSONP形式的调用

5、$.ajax()

$.ajax({
url: 'def.do',
type: 'POST',
async: true,
data: {
aaa: 'aaa', bbb: 233
},
timeout: 5000,
dataType: 'json',
beforeSend: function(XMLHttpRequest){
//XMLHttpRequest: XMLHttpRequest对象
},
success:function(data, textStatus){
//data: 返回的内容,xml、json、html
//textStatus: 请求状态,success、error、notmodified、timeout
},
error:function(XMLHttpRequest, textStatus, errorThrown){
//XMLHttpRequest: XMLHttpRequest对象
//textStatus: 错误信息
//errorThrown: 捕获的错误对象(可选)
},
complete:function(XMLHttpRequest, textStatus){
//XMLHttpRequest: XMLHttpRequest对象
//textStatus: 请求状态,success、error、notmodified、timeout
}
})

6、序列化元素

var data = $('#form').serialize(); //将表单元素序列化为字符串
var fields = $('#form').serializeArray(); //将表单元素序列化为JSON数据

四、常用例子

1、状态改变

text输入监听

$('input[type=text]').on('input propertychange', function() {
$(this).val();
});

获得焦点

$('input[type=text]').on('focus', function() {
$(this).val();
});

失去焦点

$('input[type=text]').on('blur', function() {
$(this).val();
});

禁用控件

$('input[type=text]').prop('disabled', true);

2、窗口、框架赋值

子窗口调用父窗口函数、对象

window.opener.fun();
window.opener.value;
window.opener.$("#abc").html();
$("#abc", window.opener.document).html()

子框架调用父框架函数、对象

window.parent.fun();
window.parent.value;
window.parent.$("#abc").html();
$('#abc', window.parent.document).html();

父框架调用子框架函数、对象

$("#iframe")[0].contentWindow().fun()
$("#iframe").contents().find("#abc").html();

3、jquery、js对象互相转换

var $abc = $('#abc');
var abc = $abc[0];
var $abc = $(abc);

4、响应js的超链接

<a href="javascript:void(0);">666</a>

5、js批量替换

abc.replace(/\233/g, "666");

6、js大小写

$('#abc').val().toUpperCase();
$('#abc').val().toLowerCase();

7、js引入

<script type="text/javascript" src="url"></script>
<script type="text/javascript"></script>

8、json转换

var obj = JSON.parse(str);
var str = JSON.stringify(obj);

9、延迟加载

setTimeout(function (){
test();
}, 2000);

setTimeout('test()',2000);
function test() {
alert("233");
}

10、动态调用函数

if(typeof test === 'function'){
eval('test()');
}

11、是否显示

$("#div").is(":hidden");
$("#div").is(":visible");

jQuery—常用操作的更多相关文章

  1. JQuery常用操作实现方式

    http://www.cnblogs.com/guomingfeng/articles/2038707.html 一个优秀的 JavaScript 框架,一篇 jQuery 常用方法及函数的文章留存备 ...

  2. Jquery常用操作:checkbox、select取值,radio、checkbox、select选中及其相关

    常用Jquery操作:checkbox取值.select取值.radio选中.checkbox选中.select选中及其相关: 1.影藏页面元素 使用jquery真的很方便,比如要控制div的显示与隐 ...

  3. jQuery 常用操作(转)

    一.书写规则 支持链式操作: 在变量前加"$"符号(var $variable = jQuery 对象): 注:此规定并不是强制要求. 二.寻找元素 选择器 基本选择器 层级选择器 ...

  4. jQuery 常用操作

    jQuery操作: 不像dom是通过等号赋值,它是传递参数 $('#tb:checkbox').prop('checked'); 获取值 $('#tb:checkbox').prop('checked ...

  5. jQuery常用操作

    jQuery jQuery是一个轻量级的JS库,是一个被封装好的JS文件,提供了更为简便的元素操作方式,jQuery封装了DOM. 使用jQuery 引入jQuery文件 <scrtipt sr ...

  6. 160726、jQuery常用操作

    一.简介   定义  jQuery创始人是美国John Resig,是优秀的Javascript框架: jQuery是一个轻量级.快速简洁的javaScript库. jQuery对象  jQuery产 ...

  7. jQuery常用操作(待续)

    1. input清空内容 <1> $("#选择器id").val(""); <2> $("input[name='input框 ...

  8. jQuery常用操作部分总结

    注意:$(“.xxx”)   类,一定要在前面加上点callback为完成后执行的函数名称隐藏显示:hide()   show()淡入淡出:fadeIn()  fadeOut()  fadetoggl ...

  9. jquery常用操作整理

    1.数据中添加或者删除指定元素 var  arr=['red','yello','blue']; arr.push('green');  //添加元素 arr = $.grep(arr,functio ...

随机推荐

  1. 分析js中的constructor 和prototype

    在javascript的使用过程中,constructor 和prototype这两个概念是相当重要的,深入的理解这两个概念对理解js的一些核心概念非常的重要. 我们在定义函数的时候,函数定义的时候函 ...

  2. MAC的SVN怎么设置允许.a文件上传

    首先在mac中svn的安装会去选择Cornerstone 如果遇到这个问题肯定是已经安装并准备上传.a 文件了.首先要清楚svn是默认过滤忽略.a文件的上传的,要想可以上传.a 可以通过这个简单的方法 ...

  3. 3、项目资源的提供 - PMO项目管理办公室

    PMO项目管理办公室也需要对项目相关的资源进行提供,从而针对项目的资源也进行标准化和规范化的管理.也就是说,PMO项目管理办公室就是提供项目相关的规范化资源内容,从而统一管理项目相关的内容,达到规范的 ...

  4. yii2权限控制rbac之rule详细讲解

    作者:白狼 出处:http://www.manks.top/yii2_rbac_rule.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留 ...

  5. ORACLE RETURNING 用法总结

    ORACLE RETURNING 用法总结 场景 在存储过程.PL/SQL块里需要返回INSERT.DELETE.UPDATE.MERGE等DML语句执行后的信息时使用,合理使用returning能够 ...

  6. WebServices:WSDL的结构分析

    WSDL(Web Services Description Language,Web服务描述语言)是为描述Web Services发布的XML格式.W3C组织没有批准1.1版的WSDL,但是2.0版本 ...

  7. Mysql Join

    在前面的博文中,我们已经学会了如果在一张表中读取数据,这是相对简单的,但是在真正的应用中经常需要从多个数据表中读取数据. 本章节我们将向大家介绍如何使用 MySQL 的 JOIN 在两个或多个表中查询 ...

  8. kvm/qemu/libvirt学习笔记 (1) qemu/kvm/libvirt介绍及虚拟化环境的安装

    kvm简介 kvm最初由Quramnet公司开发,2008年被RedHat公司收购.kvm全称基于内核的虚拟机(Kernel-based Virtual Machine),它是Linux的一个内核模块 ...

  9. Python资源

    25本免费的Python电子书 http://python.jobbole.com/29281/ 9本免费的Python编程书 http://python.jobbole.com/765/

  10. Eclipse开发环境JDK版本问题和校验问题

    今天遇到的两个问题: 1.启动程序报错:Unsupported major.minor version 52.0 这是JDK版本过低的问题,统一一下Build Path和java Complie中的版 ...