jQuery基础知识

题目1: jQuery 能做什么?

  • 选择网页元素
  • 改变结果集
  • 元素的操作:取值和赋值
  • 元素的操作:移动
  • 元素的操作:复制、删除和创建
  • 工具方法
  • 事件操作
  • 特殊效果
  • AJAX

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

jQuery是一个类数组对象,而DOM对象就是一个单独的DOM元素

jQuery对象转化为DOM对象:

  1. 利用数组下标的方式读取到jQuery中的DOM对象
var $div = $('div') 
var div = $div[2] 
  1. 利用jQuery的get()方法
var $div = $('div') 
var div = $div.get(2) 

DOM对象转化为jQuery对象:*

var div =  document.querySelector('div')
var $div = $('div')

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

  • jquery通过on方法绑定事件

  • bind、unbind、delegate和live都是jquery1.7以前的方法,现在已经废弃,被on和off代替

    • bind和on都是绑定事件;
    • unbind和off都是解绑事件;
    • delegate和on都可以实现事件代理;
    • live绑定事件和用.bind()来绑定事件是一样的,但.live()方法会绑定相应的事件到document元素上
  • 推荐使用on方法绑定事件

  • on( events [,selector ] [,data ], handler(eventObject) )
    示例:

// 普通事件绑定,最简单的用法
$('div').on('click', function(e){
    console.log(this);
    console.log(e);
})

// 事件委托或者事件代理,想让div 下面所有的span绑定事件,可以把事件绑定到div上
$('div').on('click', 'span', function(e){
    console.log(this);
    console.log(e);
});

// 可以在绑定的时候给事件处理程序传递一些参数
$('div').on('click', {name: 'Byron', age: 24}, function(e){
    console.log(e.data);
});
  • trigger( eventType [, extraParameters ] ):根据绑定到匹配元素的给定的事件类型执行所有的处理程序和行为
$('#foo').on('click', function() {
  alert($(this).text());
});
$('#foo').trigger('click');

题目4:jQuery 如何展示/隐藏元素?

  • 通过设置css的display属性来实现
var $div = $('div')
$div.css('display','none')
$div.css('display','block')
  • 通过增加或删除classname来实现
css:
.active{display:block}

js:
var $div = $('div')
$div.addClass('active')
$div.removeClass('active')
  • 通过jQuery的show、hide、toggle方法来实现
var $div = $('div')
$div.hide()
$div.show()
$div.toggle()//切换元素的隐藏、显示

题目5: jQuery 动画如何使用?

基础:

.hide([duration ] [,easing ] [,complete ])隐藏元素
.show( [duration ] [, easing ] [, complete ] )显示元素
.toggle( [duration ] [, easing ] [, complete ] )切换元素的显示、隐藏

这三者用法一样,用来隐藏、、显示以及切换元素的隐藏和显示。

duration:动画持续多久
easing:表示过渡使用哪种缓动函数,jQuery自身提供"linear" 和 "swing"
complete:在动画完成时执行的函数

示例:

$('div').hide(200, 'linear', function() {
    console.log('disappear')
});

渐变:

.fadeIn( [duration ] [, easing ] [, complete ] )通过淡入的方式显示
.fadeOut( [duration ] [, easing ] [, complete ] )通过淡出的方式隐藏
.fadeTo( duration, opacity [, easing ] [, complete ] )调整匹配元素的透明度,方法通过匹配元素的不透明度做动画效果
.fadeToggle( [duration ] [, easing ] [, complete ] )通过匹配的元素的不透明度动画,来显示或隐藏它们,方法执行匹配元素的不透明度动画。当被可见元素调用时,元素不透明度一旦达到0,display样式属性设置为none ,所以元素不再影响页面的布局

示例:

$('div').fadeIn('slow', function() {}
$('div').fadeOut('slow', function() {}
$('div').fadeTo('slow', 0.5, function() {}//多了一个透明度
$('div').fadeToggle('slow', function() {}

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

  • 设置元素内部 HTML 内容:$('div').html('\<h1\>Hello world\</h1\>');
  • 获取元素内部 HTML 内容:var $content = $('div').html();
  • 设置元素内部文本:$('div').text('Hello world');
  • 获取元素内部文本:var $title = $('h1').text();

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

  • 设置表单用户输入或者选择的内容: $('#username").val('dcbryant')
  • 获取表单用户输入或者选择的内容: var $username = $('#username").val();
  • 设置元素属性:
$('div').attr('color','red');
$('div').prop('color','red');
  • 获取元素属性:
var  color = $('div').attr('color');
var  color = $('div').prop('color');

attr多用于html自身原有的属性,prop多用于自定义属性

题目8: 使用 jQuery实现如下效果

效果

demo

题目9: 使用 jQuery 实现如下效果

效果

demo

题目10:实现如下效果

(http://jscode.me/uploads/default/optimized/1X/bde2c4f39009ac2dec331e18738988e1c650157b_1_690x446.gif)

Ps:当点击按钮时使用如下数据:

var products = [
    {
        img: 'http://img10.360buyimg.com/N3/jfs/t2242/92/1446546284/374195/9196ac66/56af0958N1a723458.jpg',
        name: '珂兰 黄金手 猴哥款',
        price: '¥405.00'
    },{
        img: 'http://img10.360buyimg.com/N3/jfs/t2242/92/1446546284/374195/9196ac66/56af0958N1a723458.jpg',
        name: '珂兰 黄金转运珠 猴哥款',
        price: '¥100.00'
    },{
        img: 'http://img10.360buyimg.com/N3/jfs/t2242/92/1446546284/374195/9196ac66/56af0958N1a723458.jpg',
        name: '珂兰 黄金手链 3D猴哥款',
        price: '¥45.00'
    }
];

demo
ps:用jsonp实现的加载更多,直接打开demo没有效果,用server-mock打开即可

题目11: 模仿视频6,完成 左右切换的 Tab 效果

demo

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

推荐阅读更多精彩内容

  • 一、问答 (一)说说库和框架的区别? 库和框架都是一种有别于软件、面向程序开发者的产品形式。 库的英语为 Libr...
    该帐号已被查封_才怪阅读 473评论 3 4
  • (续jQuery基础(1)) 第5章 DOM节点的复制与替换 (1)DOM拷贝clone() 克隆节点是DOM的常...
    凛0_0阅读 1,324评论 0 8
  • jQuery jQuery能实现的效果,js都能实现;js能实现的效果,jQuery未必能实现 jQuery大体分...
    Dream_丹丹阅读 194评论 0 1
  • 原文链接 http://blog.poetries.top/2016/10/20/review-jQuery 关注...
    程序员poetry阅读 16,641评论 18 503
  • 心灵鸡汤: 有志者事竟成 破釜沉舟 百二秦关终破楚 苦心人天下负 卧薪尝胆 三千越甲可吞吴 1.1重点内容 1.1...
    old帅阅读 175评论 0 0