前端知识点总结——jQuery(下)
1. 排队和并发
1.并发: 多个css属性同时变化
放在一个animate函数内的多个css属性默认并发变化
2.排队: 多个css属性先后变化
对同一个元素,先后调用多个动画API,都是排队执行
原理: 所有动画API起始并不是立刻开始动画,而仅是将当前动画函数加入元素的动画队列中等待执行。
停止动画: $(...).stop();
默认: 仅停止动画队列中,当前正在播放的一个动画,队列中后续动画,依然执行
如何停止动画,并清空队列: .stop(true)
选择器: :animated 可选择或判断一个正在播放动画的元素
2. 类数组对象操作
遍历
$(...).each(function(i,elem){
//this->当前elem
})
鄙视: $(...).each() vs $.each(数组/集合,fun)
查找
var i=$(...).index(要找的DOM元素/jq对象)
简化: 如果在一个父元素内查找子元素:
$(子元素).index();
3. 为jquery添加自定义方法
1.添加在jQuery.fn中
强调: jQuery.fn.自定义方法=function(){
//this->将来调用该方法的jq对象
}
2.调用时: $(...).自定义方法()
4. 插件: 为标准函数库或框架添加功能的第三方库
官方插件jQuery UI
使用jQueryUi:
先引入jquery.js,因为jQuery UI是基于jQuery开发的
再引入jquery-ui.js
再编写自定义脚本
包括:
交互: 自学
效果:
a. 重写了三类简单动画API,添加了新的动效
b. 为addClass/removeClass/toggleClass,也添加了动效
c. 重写了animate方法,支持颜色动画
部件
什么是部件: 具有完整样式和行为的小功能
如何使用:
1. 引入: jquery-ui.css
2. 按照部件约定,编写html内容结构
3. 引入jquery.js和jquery-ui.js
4. 在自定义脚本中,找到插件的父元素,调用插件API
原理:
侵入性: 在开发者不知情的情况下,自动添加class和行为
优点: 简单
缺点: 不可维护
jQuery UI vs bootstrap
jQuery UI 傻瓜式,侵入式
优点: 简单
缺点: 不可维护
bootstrap 少量手动添加样式和行为(自定义扩展属性)
缺点: 相比jQuery UI,稍微麻烦
优点: 可定制
5. 第三方插件
文件上传
富文本编辑器
masonry: 彩砖墙/瀑布流
6. 自定义插件
何时: 只要希望复用一块功能和样式时,都要封装为插件
前提: 必须已经用原生的html,css,jss实现了插件的功能
2种封装插件的风格:
jQuery侵入式——
1. 将插件所需的css提取出来,保存在单独的css文件中
2. 定义插件的js文件:
先检查是否提前引入了jQuery
定义插件函数,保存在jQuery的原型对象jQuery.fn中
侵入: 根据插件需要,为子元素自动添加class
为子元素绑定事件处理函数
3. 使用插件:
引入插件的css文件
在body中按插件的规定,编写html内容
引入jquery.js和插件的js文件
在自定义脚本中,查找要应用插件的父元素,调用插件函数
Bootstrap DIY式——
1. 将css拷贝到独立的css文件中
2. 编写js:
先验证是否提前加载了jQuery
查找自定义扩展属性,为其绑定事件
3. 使用插件:
引入插件的css
按照插件的HTML格式要求,编写内容
为插件的HTML元素手动添加class
为触发事件的元素添加指定的自定义扩展属性
7. jQuery的ajax API
$.ajax({
type:"get/post",
url:"xxx",
data:"rawData"/{ 变量名:值, ...}
dataType:"json",
beforeSend(){
//在发送之前触发
}
completed(){
//只要请求完成,无论成功还是失败,都触发
}
success(data){
//请求成功触发
}
error(){
//发生错误时触发
}
}).then(data=>{
... ...
}).catch(err=>{ ... })
简写
专门发送get请求
$.get(url,data,dataType).then(data=>{ ... })
专门发送get请求,接收JSON响应,并自动转为js对象
$.getJSON(url,data).then(data=>{ ... })
专门发送get请求,接收js语句响应,并执行
$.getScript(url,data)
专门发送get请求,获取一段html代码片段的响应,并自动填充到前面的父元素中
$(父元素).load("xx.php/xx.html")
强调: 不支持then!
专门简化post请求的:
$.post(url,data,dataType).then(data=>{ ... })
8. 跨域请求
跨域:
从http://store.company.com/dir/...
允许跨域请求: link, img, script
不允许跨域: xhr对象 (ajax请求)
变通: script 需要服务器返回一段可执行的js语句
服务器应该返回包含数据的一条可执行的js语句
如何实现?
客户端实现: JSONP (填充式json)
1. 在客户端定义处理函数
2. 在按钮单击事件中,动态创建script元素,src设置为服务端地址,并携带请求参数callback=函数名
3. 在服务器端,接收请求参数中的函数名,将函数名和要返回的数据,拼接为一条可执行的js语句
4. 客户端script,请求服务端php,获得可执行语句,自动调用提前定义好的函数处理数据
5. 在客户端处理函数结尾,要动态删除script
起始jQuery的ajax api都可用, 只不过,dataType必须都写成jsonp,原理同上。
服务端: header("Access-Control-Allow-Origin:*");
允许客户端使用xhr对象跨域请求!
前端知识点总结——jQuery(下)的更多相关文章
- 前端学习之jquery/下
前端学习之jquery 一 属性操作 html(): console.log($("div").html()); $(".test").html("& ...
- 前端知识点总结——jQuery(上)
1.什么是jQuery jQuery: 第三方的极简化的DOM操作的函数库第三方: 下载极简化: 是DOM操作的终极简化: 1. DOM: 增删改查2. 事件绑定:3. 动画效果:4. Ajax DO ...
- FancySelect – 更好用的 jQuery 下拉选择框插件
FancySelect 这款插件是 Web 开发中下拉框功能的一个更好的选择.FancySelect 使用方便,只要绑定页面上的任何 Select 元素,并调用就 .fancySelect() 就可以 ...
- js前端分页之jQuery
锋利的js前端分页之jQuery 大家在作分页时,多数是在后台返回一个导航条的html字符串,其实在前端用js也很好实现. 调用pager方法,输入参数,会返回一个导航条的html字符串.方法的内部比 ...
- 前端学习之jquery
前端学习之jquery 1. 什么是jQuery对象? jQuery对象就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的.如果一个对象是jQuery对象,那么它 ...
- Vue.js中前端知识点总结笔记
1.框架和库的区别: 框架:framework 有着自己的语法特点.都有对应的各个模块库 library 专注于一点 框架的好处: 1.提到代码的质量,开发速度 2.提高代码的复用率 3.降低模块之间 ...
- Web前端-Ajax基础技术(下)
Web前端-Ajax基础技术(下) 你要明白ajax是什么,怎么使用? ajax,web程序是将信息放入公共的服务器,让所有网络用户可以通过浏览器进行访问. 浏览器发送请求,获取服务器的数据: 地址栏 ...
- 前端知识点总结(HTML)
前端知识点总结(HTML) 一,头部常用的标签 1,link标签 (1),设置ico图标 <link rel="shortcut icon" href="favi ...
- 前端基础之:JQuery(可编辑版)
前端基础之jquery 一 jQuery是什么? [1] jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多 javascript高手加入其team. [2] ...
随机推荐
- Java 开发中常用的网站地址
博客地址:http://www.moonxy.com 一.前言 在日常的开发中,通常需要访问或者设置不同的网站来获取需要的数据,不如我们都知道 Linux 系统版本比较多(例如:Ubuntu.Cent ...
- charles 设置为chrome代理
本文参考:charles 设置为chrome代理 将charles设置为chrome的代理 需要注意的是,Chrome 和 Firefox 浏览器并不一定使用的就是本机,可能是一些代理工具,而 Cha ...
- (五)Linux内存管理zone_sizes_init
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...
- SqlServer Left、Right、CharIndex函数
LEFT 函数:返回字符串中从左边开始指定个数字符 RIGT.H 函数:返回字符串从右边开始指定个数字符 len函数:LEN 函数返回文本字段中值的长度. CHARINDEX函数:CHARINDEX ...
- jenkins自动化部署项目7 -- 新建job(将服务代码部署在windows上)
关于构建结束后jenkins会kill所有衍生子进程的官方解决方案:https://wiki.jenkins.io/display/JENKINS/Spawning+processes+from+bu ...
- 数据结构与算法(C/C++版)【数组】
第五章<数组> 一.概念 根据数组中存储的数据元素之间的逻辑关系,可以将数组分为 : 一维数组.二维数组.….n维数组.n维数组中,维数 n 的判断依据是:根据数组中为确定元素所在位置使用 ...
- Spring MVC-从零开始-web.xml中classpath和classpath* 有什么区别
web.xml中classpath和classpath* 有什么区别?classpath:只会到你的class路径中查找找文件;classpath*:不仅包含class路径,还包括jar文件中(cla ...
- ibatis 学习
1.$与#的区别: 用到#和$来获取传的参数值,其中#是将传来的值替换(如果是字符串,会将‘’带着替换,比如上面$value$,用#value#的话,就会出错.#与$的使用区别:$中间的变量就是直接替 ...
- Go语言入门教程(十)之函数
Hello 各位小伙伴大家好,我是小栈君,假期一眨眼就过去了.不知道大家玩的是否开心呢? 上次我们讲到了关于Go语言的流程控制,小栈君也希望小伙伴跟着小栈君一步一个脚印的敲一下代码,相互进步.本期我们 ...
- 文件操作——RandomAccessFile
文件操作——RandomAccessFile 构建RandomAccessFileJava提供了一个可以对文件随机访问的操作,访问包括读和写操作.该类名为RandomAccessFile.该类的读 ...