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(下)的更多相关文章

  1. 前端学习之jquery/下

    前端学习之jquery 一 属性操作 html(): console.log($("div").html()); $(".test").html("& ...

  2. 前端知识点总结——jQuery(上)

    1.什么是jQuery jQuery: 第三方的极简化的DOM操作的函数库第三方: 下载极简化: 是DOM操作的终极简化: 1. DOM: 增删改查2. 事件绑定:3. 动画效果:4. Ajax DO ...

  3. FancySelect – 更好用的 jQuery 下拉选择框插件

    FancySelect 这款插件是 Web 开发中下拉框功能的一个更好的选择.FancySelect 使用方便,只要绑定页面上的任何 Select 元素,并调用就 .fancySelect() 就可以 ...

  4. js前端分页之jQuery

    锋利的js前端分页之jQuery 大家在作分页时,多数是在后台返回一个导航条的html字符串,其实在前端用js也很好实现. 调用pager方法,输入参数,会返回一个导航条的html字符串.方法的内部比 ...

  5. 前端学习之jquery

    前端学习之jquery 1.   什么是jQuery对象? jQuery对象就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的.如果一个对象是jQuery对象,那么它 ...

  6. Vue.js中前端知识点总结笔记

    1.框架和库的区别: 框架:framework 有着自己的语法特点.都有对应的各个模块库 library 专注于一点 框架的好处: 1.提到代码的质量,开发速度 2.提高代码的复用率 3.降低模块之间 ...

  7. Web前端-Ajax基础技术(下)

    Web前端-Ajax基础技术(下) 你要明白ajax是什么,怎么使用? ajax,web程序是将信息放入公共的服务器,让所有网络用户可以通过浏览器进行访问. 浏览器发送请求,获取服务器的数据: 地址栏 ...

  8. 前端知识点总结(HTML)

    前端知识点总结(HTML) 一,头部常用的标签 1,link标签  (1),设置ico图标 <link rel="shortcut icon" href="favi ...

  9. 前端基础之:JQuery(可编辑版)

     前端基础之jquery   一 jQuery是什么? [1]   jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多 javascript高手加入其team. [2]   ...

随机推荐

  1. 误删除系列一:linux的bin目录误删除后恢复操作

    感言:一失足成千古恨,一不小心就把/usr/bin下所有的命令都删除了,当你以为自己很熟练时,当你以为自己操作对时,可能就是失手的时候,还好这次只是一个测试环境....God 恢复过程:(以下是在vs ...

  2. 【学习笔记】第六章 python核心技术与实践--深入浅出字符串

    [第五章]思考题答案,仅供参考: 思考题1:第一种方法更快,原因就是{}不需要去调用相关的函数: 思考题2:用列表作为key在这里是不被允许的,因为列表是一个动态变化的数据结构,字典当中的key要求是 ...

  3. DirectX12 3D 游戏开发与实战第一章内容

    DirectX12 3D 第一章内容 学习目标 1.学习向量在几何学和数学中的表示方法 2.了解向量的运算定义以及它在几何学中的应用 3.熟悉DirectXMath库中与向量有关的类和方法 1.1 向 ...

  4. .NET Core 3.0即将发布!

    期待已久的.NET Core 3.0即将发布! .NET Core 3.0在.NET Conf上发布.大约还有9个多小时后,.NET Conf开始启动. 为期3天的大概日程安排如下: 第1天-9月23 ...

  5. 给idea设置默认使用的JDK

    一,前言 在文章给idea设置默认使用的maven配置中我给我的idea设置了默认使用的maven,并且在setting.xml文件中,设置了本地的maven仓库,这样就不会使用maven默认在C盘的 ...

  6. github认证登陆

    使用github OAuth实现用户登录 做登录功能时,允许使用第三方网站的身份,这称为"第三方登录". 原理 github内的认证方法 在github上申请OAuth App,进 ...

  7. rpm方式升级cenos6.7内核

    最近因为yarn集群问题需要配置cgroup.但是配置完成后操作系统内核奔溃. 查找资料后发现升级内核可以解决问题.在领导的大力支持下,对生产环境的计算节点(nodemanager)进行了批量升级内核 ...

  8. connection pool exhausted

    1.发现问题 生产环境发现有一些redis报错日志 connection pool exhausted.如果redis中没有数据 就直接回源 查DB.暂时不会有什么大问题.中文意思是连接池耗尽. 2. ...

  9. java-不定项参数(可变参数)的作用和使用方式

    引言: 我们在编写方法的过程中,可能会遇见一个方法有不确定参数个数的情况.一般我们会用方法重载来解决问题: 1 //方法重载,解决参数个数不确定问题 2 public void method(); 3 ...

  10. 杭州蓝松科技---短视频SDK介绍

    蓝松短视频的口号和 更新周期: 我们的口号是:  蓝松短视频  任意个性化. 我们是杭州蓝松科技,  专业做视频短视频SDK的技术团队. 我们提供 Android/IOS平台上的 短视频编辑SDK,  ...