进阶-14

jQuery 能做什么?

jquery是一个丰富的js库,内部对js的很多复杂的方法进行了封装和加工,比如js很多方法名很冗长,jquery封装后方法就变得简便了,也考虑到了跨浏览器兼容问题,这样我们用js时需要考虑的很多问题它都帮我们解决了,这样我们使用时就比js代码要方便,高效的多。

jQuery 对象和 DOM 原生对象有什么区别?如何转化?

  • 区别:
    jquery对象通常用jquery的方法$(’’)来得到,可以使用jquery提供的方法来操作html的数据
    DOM原生对象只能用js提供的方法,如getElementById,getElementByTagName,有的获取的是一个元素,有的获取的是一个数组。
  • 转化方法:
    普通dom对象转化成jq对象的方法
    普通的dom对象的话只需要用$()包裹一下就好了
var yangchenjian=document.getElementById("yangchenjian"); // 原生获取
var $yangchenjian = $(yangchenjian) 
    ‘$(yangchenjian)  //这就算是把原生的转化成jq对象了经过转化jq封装好的api就可以正常使用了’

** jq对象转化成原生对象 **
通过jquery自身提供的.get[index] 这个方法来完成转化

var yangchenjian=document.getElementById("yangchenjian");
var $yangchenjian = $(yangchenjian) ;
var yangchenjian = $yangchenjian.get[0]; //完成原生转化


jQuery中如何绑定事件?bind、unbind、delegate、live、on、off都有什么作用?推荐使用哪种?使用on绑定事件使用事件代理的写法?

  • jQuery中如何绑定事件
现在常用的事件代理方法是on方法,
on(events,[selector],[data],fn)
- events: 触发的事件类型 点击 双击 等等
- selector: 事件委托的时候用,用于过滤器的触发事件的选择器元素的后代
- data: 当一个事件被触发时要传递event.data给事件处理函数。
- fn: 用户触发后要做的事情是个函数方法

----------------------------下面写关于on的例子-------------------------------

$('p').on('click',function(){
 alert('1234')
})
//阻止默认事件
$('from').on('submit',function(e){
 e.stopPropagation();
})
//事件委托 只有ul内部中的li才能触发事件p标签是没有触发效果的
$(document).ready(function () {
function test(e) {
 console.log($(this).text())
 console.log(e.data.name)
} 
$('.yu').on('click.la','li', {name: "杨晨健"},test)

})
</script>
 <ul class="yu">
  <li>hahha</li>
  <li>ahdkada</li>
  <li>dadada</li>
  <p>adadadadadadada</p>
 </ul>
//取消li中的触发事件
$('.yu').off('.la')
一定要注意应该是.事件名才行,别忘了带上‘.’
  • 推荐使用on方法来完成事件绑定,同时应该记住 .off( events [, selector ] )方法用来对应on的绑定方法。注意:多个事件绑定的时候最好给触发事件取一个名字,这样解绑事件的时候不至于一下子全给解绑了 例子:node.on('click.eventname',function(){}) 解绑的时候就用node.off('.eventname')

  • bind 早期的事件绑定方法,现在已经被弃用了,unbind是其对应的解绑事件的方法。

  • delegate(selector,[type],[data],fn) 用来执行事件委托(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。

  • live(type, [data], fn),给所有匹配的元素附加一个事件处理函数,即使这个元素是以后再添加进来的也有效,但是在1.7之后已经不被推荐使用了,如果想添加事件处理就用on方法就好,如果用的是老版本的jq就用delegate来代替live


jQuery 如何展示/隐藏元素?

show()方法完成元素的展示
hide()方法完成元素的隐藏

<script>
  $('.show').on('click',function (){
   $('p').show(100)
   
  })
  $('.hide').on('click',function () {
   // body...
   $('p').hide(100)
  })
})

  </script>

  <ul class="yu">
   <li>hahha</li>
   <li>ahdkada</li>
   <li>dadada</li>
   <p>adadadadadadada</p>
  </ul>
  <button class="show">显示</button>
  <button class="hide">隐藏</button>
</body>
</html>

jQuery 动画如何使用?

<!doctype html>
<html lang="zh-cn">
<head>
  <meta charset="UTF-8">
  <meta name="viewport"
        content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
  <style type="text/css">
   *{
    padding: 0;
    margin: 0;
   }
   button{
    padding: 5px;
   }
   .block{
    width: 50px;
    height: 50px;
    background-color: pink;
    position: relative;
   }
   .clear{
    clear: both;
   }
</style>
</head>
<body>
  <script>

$(document).ready(function () {
    var block = $('.block')
   var start = $('.start')
   var stop = $('.stop')
   var reset = $ ('.reset')
   
  start.on('click',function () {
   block.animate({
    width:'200px',
    height:'200px'
    },1200,"swing",function () {
     console.log('回调函数 ')
    });
   block.animate({
    left:'400px',
    },1200,"swing",function () {
     console.log('👈移动 ')
    });
   block.animate({
    left:'0px'
    },1200,"swing",function () {
     console.log(' 👉移动 ')
    });
    block.animate({
    width:'50px',
    height:'50px'
    },1200,"swing",function () {
     console.log(' 恢复啦 ')
    });

 })
   reset.on('click',function () {
     console.log('复位啦')
  block.finish()
 })
  
 stop.on('click',function () {
  console.log('停止了正在运行的动画')
  block.stop(true,true)
 })

})

  </script>
  <div class="block"></div>
  <button class="start">动画开始</button>
  <button class="stop">暂停</button>
  <button class="reset">复位</button>

</body>
</html>

如何设置和获取元素内部 HTML 内容?如何设置和获取元素内部文本?

//获取元素内部HTML
$('selector').html()

//获取元素内部文本
$('selector').text()

//设置元素内部HTML
$('selector').html(' 内容放在里面 ')

//设置元素内部文本
$('selector').text(' 内容放在里面 ')

如何设置和获取表单用户输入或者选择的内容?如何设置和获取元素属性?

//设置表单的内容
$('selector').val('请输入您的账号')

//设置元素属性
$('selector').attr('name','野猪'):设置该元素中的name属性值为 野猪;

//获取用户输入内容
$('selector').val()

//获取元素属性
$('selector').attr('name'):获取该元素中的name属性;

题目8-11代码展示

8-代码展示

9-代码展示

10-代码展示

11-代码展示

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

推荐阅读更多精彩内容

  • 1: jQuery 能做什么? 1. 选择网页元素 可以当作CSS选择器使用,简单的比如 $('#id'),复杂的...
    晓风残月1994阅读 293评论 0 1
  • 题目1: jQuery 能做什么? JQuery 是个JS库,一些效果JS要用繁重的代码才能实现,但可以通过jQ一...
    饥人谷_严琰阅读 302评论 0 0
  • 题目1: jQuery 能做什么? jQuery 是一个高效、精简并且功能丰富的 JavaScript 工具库。它...
    饥人谷_星璇阅读 153评论 0 0
  • 题目1: jQuery 能做什么? 选择网页元素 改变结果集 元素的操作:取值和赋值 元素的操作:移动 元素的操作...
    cheneyzhangch阅读 421评论 0 1
  • 心情这种东西真的不好说,比天气的变化还快,我羡慕那些能很快调节自己心情的人,特别是不好的心情,就像我现在是调节不好...
    小浅兮阅读 73评论 0 0