jqueryDOM

jQuery Dom

创建元素

只需要把DOM字符串传入$方法即可返回一个jQuery对象

var obj = $('<div class="test"><p><span>Done</span></p></div>');

Question

以下 jQuery 方法有什么作用?如何使用?给出范例

  • .append()
  • .prepend()
  • .before()
  • .after()
  • .remove()
  • .empty()
  • .html()
  • .text()

append

$('body').append($('<p>hello</p>'))

在body的最后面添加了一个p标签hello

prepend

$('body').prepend($('<p>xixi</p>'))

在body的最前面添加一个p标签xixi

before

$('#hello').before($('<p>在前面添加一个标签</p>'))

在#hello前面添加一个标签

after

$('.wrap').after($('<p>cyw</p>'))

//输出1,cyw,2

remove

删除被选定的元素及其子元素

$('.wrap').remove()

empty

清空被选中的子元素

$('.wrap').empty()

没有删除wrap元素,但删除了他所有的子元素

html

把元素里面的内容换成html标签里面的内容

text

和innerText基本相同

node.text()和node.html()有什么区别?

html()

  • 无参html():取得第一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档,返回的是一个String
<div><p>Hello</p></div> 
$("div").html(); 
结果:Hello
  • 有参html(val):设置每一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档。返回一个jquery对象
<div></div> 

$("div").html("<p>Nice to meet you</p>"); 
结果:[ <div><p> Nice to meet you</p></div> ]

text()

  • 无参text():取得所有匹配元素的内容。结果是由所有匹配元素包含的文本内容组合起来的文本。返回的是一个String
<p><b>Hello</b> fine</p> 
<p>Thank you!</p> 

$("p").text(); 
结果:HellofineThankyou! 
  • 有参text(val):设置所有匹配元素的文本内容, 与 html() 类似, 但将编码 HTML (将 "<" 和 ">" 替换成相应的HTML实体).返回一个jquery对象
<p>Test Paragraph.</p> 
$("p").text("<b>Some</b> new text."); 
结果:[ <p><b>Some</b> new text.</p> ]

jQuery核心方法

jQuery的对象转化

jQuery的对象转化为原生DOM对象

$('#p1')[0]

jQuery对象选择jQuery对象

$p.eq(2)

原生DOM对象转化为jQuery对象

$(document.querySelector('#p1'))

查看jQuery对象是否为空

jQuery.length是否为0

小技巧

当不知回调函数的参数是多少的时候
console.log(arguments)

回调函数中this ==== node

jQuery === $

.each

遍历一个对象,为每一个匹配元素执行一个函数

jQuery.each(collection,function)

一个调用的迭代函数,它可以用来无缝迭代对象和数组

.map(callbaxk(index,domElements))

通过一个函数匹配当前集合中的每个元素,产生一个包含新的jQuery对象

jQuery.extend([deep,] target [, object1 ] [, objectN ] )

通过extend()进行合并操作

原生DOM对象是什么

原生DOM对象是指document.querySelector()所选择的对象

.ready

$(function(){})
$.ready(function(){})

window.onload()和$(ducument).ready()的不同

window.onload是等待所有的资源加载完成之后再进行加载函数

$(document).ready是等待节点的布局完成以后再加载函数

button.disabled 和 button.getAttribute('disabled') 有什么区别?

  • 「node.property」的方式不能获取自定义属性,
  • 「node.getAttribute()」的方式可以获取自定义属性
  • 「node. getAttribute()」获取自定义属性忽略属性的大小写
    「node.getAttribute()」获取自定义属性得到的值的类型总是字符串

介绍以下 jQuery 函数的用法,给出范例

.val

<input type="text" value="1234" class='box'>
$('input').val('newvalue')
//输出input的框内value变为newvalue

.attr

<input type="text" value="1234" class='box'>
console.log($('input').attr('type'))
//输出 text

removeAttr

<input type="text" value="1234" class='box'>
$('input').removeAttr('value')
//输出value为空的input框

pop

与attrivute方法类似

css

var color = $(this).css('background')

$( this ).css( "background-color", "yellow" );

addClass

为元素添加class,不是覆盖原class,是追加,也不会检查重复

removeClass

移除元素单个/多个/所有class

.hasClass(className)

检查元素是否包含某个class,返回true/false

toggleClass

toggle是切换的意思,方法用于切换

jQuery 对象和原生 Dom 对象有什么区别?如何相互转换?

jQuery对象是通过$符号获得的符号,而原生Dom对象是通过document.querySelector()获得的对象

jQuery的对象转化为原生DOM对象

$('#p1')[0]

jQuery对象选择jQuery对象

$p.eq(2)

原生DOM对象转化为jQuery对象

$(document.querySelector('#p1'))

介绍以下 jQuery 方法的用法,给出范例

.each

$('p').each(function( idx, node){
            console.log($(node).text(idx + ':' + 'hello'))
        })

//在每一个p后面加上hello

$.extend()

当我们提供两个或多个对象给$.extend(),对象的所有属性都添加到目标对象(target参数)。

var object1 = {
              apple: 0,
              banana: { weight: 52, price: 100 },
              cherry: 97
        };
        var object2 = {
              banana: { price: 200 },
              durian: 100
        };

            // Merge object2 into object1
        $.extend( object1, object2 );
        console.log(object1)

输出两个Obj所有属性的参数

clone()

通常我们将页面上一个元素插入到DOM里另一个地方,它会被从老地方移走,类似剪切的效果
但是我们如果需要的是复制而不是剪切,我们可以像下面这样写代码:

    <div class="container">
          <div class="goodbye">
            Goodbye
            <div class="hello">Hello</div>
          </div>    
    </div>
    <script>
        $('.hello').clone().appendTo('.goodbye');
    </script>

index

$('p').eq(20).index()

输出20

.ready

$(function(){})
$.ready(function(){})

$(document).ready是等待节点的布局完成以后再加载函数

window.onload和$(document).ready有什么区别?document.onDOMContentLoaded呢?

window.onload和$(document).ready都是页面加载时我们就去执行一个函数或者动作,具体细节上还是有区别的

最基本区别

1.执行时间

window.onload必须等到页面内包括图片的所有元素加载完毕后再去执行。
$(document).ready()时DOM结构回执完毕后就执行,不必等到加载完毕。

2.编写个数不同

window.onload不同同时编写多个,如果有多个window.onload方法,只会执行一个
$(document).ready()可以同时编写多个,并且可以得到执行

3.简化写法

window.onload没有简化写法
(document).ready(function(){})可以简写成(function(){});

点击 icon 后会切换播放和暂停两种状态

https://jsbin.com/?html,output

.find 后面选择class需要加上'.'

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

推荐阅读更多精彩内容