26.jQuery part1

1. jQuery 能做什么?
  • 获取页面元素
  • 修改页面的样式
  • 修改页面元素的内容
  • 响应用户的页面操作
  • 为页面添加动态效果
  • 统一的Ajax操作
  • 简化了常见的js方法
2. jQuery 对象和 DOM 原生对象有什么区别?如何转化?

区别:

  • jQuery对象是通过通过jQuery包装DOM对象后产生的对象。
    • jQuery对象不能使用DOM对象的任何方法,如$('#id').innerHTML是错误的,可以用$('#id').html()代替
  • DOM对象是通过原生js中的getElementById,querySelector等方法返回的DOM元素
    • DOM对象也不能使用jQuery的方法

转化:

  • jQuery对象转换为DOM对象:通过[index]get(index)
var $obj = $('#id') //jQuery对象
var obj = $obj[0]  //DOM对象,或者var obj = $obj.get(0)
  • DOM对象转换为jQuery对象:用$()将DOM对象包装起来
var obj = document.getElementById('id') //DOM对象
var $obj = $(obj)  //jQuery对象
3.jQuery中如何绑定事件?bind、unbind、delegate、live、on、off都有什么作用?推荐使用哪种?使用on绑定事件使用事件代理的写法?

1.通过.on(events [,selector] [,data] ,handler(eventObject))绑定;其中

events:一个或多个空格分隔的事件类型和可选的命名空间,或仅仅是命名空间,比如"click", "keydown.myPlugin" 或者 ".myPlugin"
selector:一个选择器字符串,用于过滤出被选中的元素中能触发事件的后代元素。如果选择器是 null 或者忽略了该选择器,那么被选中的元素总是能触发事件
data:当一个事件被触发时,要传递给事件处理函数的event.data
handler(eventObject):事件被触发时,执行的函数。若该函数只是要执行return false的话,那么该参数位置可以直接简写成 false

  • .bind() 3.0版本弃用
    为每一个匹配元素的特定事件(如click)绑定一个事件处理函数
  • .unbind() 3.0版本弃用
    bind方法的反向操作,从每一个匹配元素删除绑定的事件
  • .delegate() 3.0版本弃用
    为所有匹配选择器的元素绑定事件处理函数,元素可以是现在或将来的元素
  • live() 1.7版本弃用
    附加一个事件处理器到匹配目前选择器的所有元素,现在和未来。
  • .on() 推荐使用
    提供了绑定事件处理的所有功能
    为所有匹配的元素绑定事件处理函数
  • .off() 推荐使用
    移除用.on()绑定的事件处理程序

3..on()绑定事件使用事件代理

//第二个参数为子元素的选择器,在$('ul')触发click事件后,会检查target是否为li元素,
//true的话再调用事件处理函数
$('ul').on('click', 'li', function (e){
  console.log(e.target);
});
4.jQuery 如何展示/隐藏元素?
  • .show()显示选中元素
  • .hide()隐藏选中元素,hide()方法会记住元素显示时的display值,当调用.show()时根据原来的值显示元素
  • .toggle()切换元素可见状态
  • .fadeIn()通过淡入的方式显示选中元素
  • .fadeOut()通过淡出的方式隐藏选中元素,一旦透明度为0,元素的display设置为none
  • .fadeToggle()通过匹配的元素的不透明度动画,来显示或隐藏它们,一旦透明度为0,元素的display设置为none
  • slideUp()用滑动动画隐藏匹配元素
  • slideDown()用滑动动画显示匹配元素
  • slideToggle()用滑动动画切换匹配元素显示状态

以上参数都可以有[duration] [,easing] [,complete]三个参数,其中
duration:动画持续多久,为数字或normal,slow,fast或自定义
easing:表示过渡使用哪种缓动函数,jQuery自身提供"linear" 和 "swing"
complete:在动画完成时执行的函数

  • .css('display', 'none')//或者inline-block,block……

效果

5.jQuery 动画如何使用?

参考
1.jQuery 效果 - animate() 方法

  • $(selector).animate(styles[,speed][,easing][,callback])

    • styles规定产生动画效果的CSS样式和值,其中CSS样式使用驼峰形式的DOM名称如fontSize代替font-size
    • speed规定动画的速度,数值或normal,slow,fast
    • easing规定在不同的动画点中设置动画速度的 easing 函数,内置swing,linear,可使用扩展插件
  • callback规定动画执行完成后执行的函数

  • $(selector).animate(styles,options)

    • styles同上
    • options额外的动画效果
      • speed - 设置动画的速度
      • easing - 规定要使用的 easing 函数
      • callback - 规定动画完成之后要执行的函数
      • step - 规定动画的每一步完成之后要执行的函数
      • queue - 布尔值。指示是否在效果队列中放置动画。如果为 false,则动画将立即开始
      • specialEasing - 来自 styles 参数的一个或多个 CSS 属性的映射,以及它们的对应 easing 函数

使用介绍

  • 简单动画
<head>
    <meta charset="UTF-8">
    <title>jquery</title>
    <script src="./jquery-3.2.0.js"></script>
    <style>
      .hunger{
        height: 200px;
        width: 200px;
        background: lightblue;
        position: relative;
      }
    </style>
</head>
<body>
    <div class="hunger"></div>
    <script>
 //动画
     $('.hunger').click(function(){
      $(this).animate({
        left:'50px',top:'50px'
      },1000)
    })
    </script>
</body>
简单动画
  • 累加、累减动画
    left:'50px',top:'50px'改为left:'+=50px',点击一次,右移15px
累加、累减动画
  • 顺序执行多个动画
    • 可以在链式调用animate()或者回调的方式实现顺序动画
    • 也可以用遍历,将js部分改为以下,点击元素依次执行array里面的动画
//动画参数
  var array = [
    {left:'50px',top:'50px'},
    {left:'0'},
    {top:'0'},
    {width:'50px',height:'50px'}
  ]
//依次执行
  $('.hunger').click(function(){
    array.forEach(function(ele){
      $('.hunger').animate(ele,1000)
    })
  })
顺序执行动画
6.如何设置和获取元素内部 HTML 内容?如何设置和获取元素内部文本?

$(selector).html()获取元素内部HTML内容
$(selector).html(string)通过传入string设置元素内部HTML内容

<div class="hunger">
  <p>12</p>
</div>
<script>
  console.log($('.hunger').html())   //<p>12</p>
  $('.hunger').html('<div>123</div>')
  console.log($('.hunger').html())   //<div>123</div>
</script>

$(selector).text()获取元素内部文本内容
$(selector).text(string)通过传入string设置文本内容

<div class="hunger">
  <p>12</p>
</div>
<script>
  console.log($('.hunger').text())   //12
  $('.hunger').text('1234')
  console.log($('.hunger')[0])       //<div class="hunger">1234</div>
  console.log($('.hunger').text())   //1234
</script>
7.如何设置和获取表单用户输入或者选择的内容?如何设置和获取元素属性?
$(selector).val()        //获取表单内容
$(selector).val(value)  //通过传入value设置表单内容
$(selector).attr(attributeName)       //获取元素属性
$(selector).attr(attributeName,value) //通过传入value设置属性值
8.

task 8

9.

task 9

10.

task 10

11.

task 11

`

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,330评论 0 2
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,167评论 0 1
  • 1、 jQuery 能做什么? jquery是一个丰富的js库,内部对js的很多复杂的方法进行了封装和加工,比如j...
    zh_yang阅读 1,403评论 6 13
  • 原文链接 http://blog.poetries.top/2016/10/20/review-jQuery 关注...
    程序员poetry阅读 16,641评论 18 503
  • 她告诉他:“我每天放学回家的小路很黑”本来她以为他会安慰她说:“小心点儿。要不我送你吧”但他说:“那你不走那条...
    朱海玉y阅读 137评论 0 1