jQuery--第一节

一、
1、在jQuery中,可以直接使用$符号,或者使用jQuery变量名,它俩完全一致
console.log(jQuery === $); // true
2、jQuery本身是函数,拥有自己的属性和方法
console.log($);//function ( selector, context ) {…
3、在ready方法中去执行正式的操作,等DOM加载完毕后去执行
$(document).ready(function () {
console.log('文档加载完毕');
});
简写为:
$(function () {
console.log('文档加载完毕');
}
3、将JQ对象与DOM对象转换

           // 获取元素
            var h2JQ = $('.title');
            console.log(h2JQ);

            // 将JQ对象转为DOM对象
            var h2DOM = h2JQ.get(0);
            // console.log(h2JQ[0]);

            // 将DOM元素转为JQ元素
            console.log($(h2DOM));

4、 使用$获取元素

            // var h2 = $('h2');
            // // 绑定事件
            // h2.on('click', function () {
            //     // 修改内容
            //     h2.html('$');
            // });

            // $('h2').on('click', function () {
            //     $(this).html('$');
            // });

二、选择器


            // 通过id查找元素
            // $('#div2').css('color', 'blue');
            // 通过class
            // $('.div1').css('color', 'red');
            // 通过标签名
            // $('span').css('color', 'yellow');

            // 群组选择器
            // $('span, p').css('background-color', 'pink');

            // 后代选择器
            // $('div span').css('font-size', '2em');

            // 如果符合选择器的元素有多个,则可以全部选出,并且设置样式的时候,可以同时给数组内容所有元素添加
            //  $('div').css('border', '1px dashed blue');

            // 直接子级选择器
            // $('.container > span').css('border', '1px dashed red');

            // first
             //$('li:first').css('color', 'blue');
            // last
            // $('li:last').css('color', 'red');

            // :first-child
            // $('li:first-child').css('color', 'blue');
            // :last-child
            // $('li:last-child').css('color', 'red');

            // 如果使用:fist或者:last,则没有父级标签
            // 如果使用:first-child或者:last-child,则从子集的区域内查找

            // eq()
            // $('li:eq(7)').css('background-color', 'yellow');

            // nth-child() 
            //$('li:nth-child(3)').css('background-color', 'yellow');

            // :eq和:first类似,没有父级标签,不区分位置,并且下标从0开始
            // :nth-child和:first-child类型,区分位置,从子集的区域内查找,下标从1开始

            // :not()用于排除某些元素,如果是多个,直接在not()后面的小括号中使用群组选择器
            // $('.wrapper > *:not(p, h3)').css('background-color', 'cyan');

            // 代表奇数元素,根据下标,从0开始
            // $('li:odd').css('background-color', 'blue');
            // $('li:even').css('background-color', 'blue');

            // 代表奇数元素,根据下标,从1开始
            // $('li:nth-child(odd)').css('background-color', 'blue');
            // $('li:nth-child(even)').css('background-color', 'blue');

            // 通过属性选择器获取元素
            // $('p[title]').html('我是通过属性选择器修改后的内容');

            // 表单对于的选择器
            // $(':input').css('background-color', 'blue');
            // 可以直接编写input的type的值去选取元素
            // $(':text').css('background-color', 'blue');
            // $(':password').css('background-color', 'blue');
            // $(':checkbox').css('background-color', 'blue');

            // 选取默认选中的元素
            // $(':checked').css('background-color', 'red');

            // $('h2').css('color', 'blue').on('click', function () {
            //     alert('h2');
            //     $(this).slideUp(2000);
            // }).css('background-color', 'yellow');

三、DOM操作
1、 append
appendTo
prepend
prependTo
after
insertAfter
before
insertBefore
remove
clone
empty
replaceWith
replaceAll

// 原生JS
        // var header = document.createElement('div')
        // header.className = 'header';
        // document.querySelector('.container').appendChild(header);

        $(function () {
            // 创建标签
            // var header = $('<div class="header"></div>');

            // append() 拼接元素
            // $('.container').append(header);

            // appendTo()
            // header.appendTo($('.container'));
            // 可以直接把容器的选择器写成参数,而不添加$()
            // header.appendTo('.container');


            // $('<div class="header"></div>').appendTo('.container').append('<h1>标题</h1>');

            // 使用jq创建结构的时候,可以同时创建多个标签
            // $('<div class="header"><h1>我是标题</h1></div>').appendTo('.container');
            // $('<div class="header">' +
            //     '<h1>我是标题</h1>' +
            //   '</div>').appendTo('.container');

            // 如果创建的标签结构比较复杂,代码比较多。
            // 还折成一行就会造成代码可读性降低
            // 可以使用ES6的模板字符串解决这个问题
            // 模板字符串使用 `` 代表结构,所有内部的内容,都是字符串的内容,可以换行写
            // 模板字符串内部如果需要使用变量的话,直接使用${},在内部编写就可以解析
            // var str = '我是内容';
            // $(`<div>
            //       <div>
            //           <div>${ str }</div>
            //       </div>
            //   </div>`).appendTo('body');


            // $('<h1>h1</h1>').appendTo('.container');
            // $('<h2>h2</h2>').appendTo('.container');

            // 使用after()和before进行兄弟元素的拼接
            // $('h2').before('<hr />');
            // $('h1').after('<hr />')

            // 和append 、 appendTo不同的在于叫 insertAfter / insertBefore,进行将前面的元素拼接到后面的元素上下
            // $('<hr />').insertAfter('h1');
            // $('<hr />').insertBefore('h2');
            
            //与append相反,在元素里的最前面插入
            // $('<hr />').prependTo('.container');
            // $('.container').prepend('<hr />');

            // append
            // appendTo
            // prepend
            // prependTo
            // after
            // insertAfter
            // before
            // insertBefore

            // 插入一个标签
            // $('<h2>标题</h2>').appendTo('.container');
            // $('<h2>标题</h2>').appendTo('.container');
            // $('<h2>标题</h2>').appendTo('.container');
            // $('<h2>标题</h2>').appendTo('.container');

            // 使用h1标题替换掉h2标题
            // $('h2:eq(1)').replaceWith('<h1>标题</h1>');
            // $('<h1>标题</h1>').replaceAll('h2:eq(1)');
            // 使用 replaceWith 或者 replaceAll 可以进行标签的替换

            // 移除元素本身
            $('<h1>我是被移除的元素</h1>').appendTo('.container').remove();

            // 清空元素内容
            $(`<ul>
                <li>li1</li>
                <li>li2</li>
                <li>li3</li>
            </ul>`).appendTo('.container').empty();
            // 如果使用jq同时创建了多层的标签结构,则返回值代表最外层

            // 复制
            $('.container').clone().appendTo('body');

        });

2、

$(function () {
            // 创建标签并拼接
            var div = $(`<div>
                    <h2>我是h2标题</h2>
                    <h3>我是h3标题</h3>
                </div>`).appendTo('.container');

            // 使用html()方法,获取全部内容
            // console.log(div.html());
            // 使用text()方法,获取文本内容
            // console.log(div.text());

            // 如果html()方法有参数,则修改内容
            // div.html('<h1>我是h1</h1>');
            // text()有参数的情况和html()类似
            // div.text('我是修改后的文字');

            // 注意: 在JQ中,不是所有地方都能使用链式语法。当某个方法具有自定特定的放回值的情况,则不能使用链式语法
            // div.html().css('background-color', 'red');


            // val()方法是为了给表单元素的value属性使用。有参则设置,无参则取值
            // $(':input').val('1831468462');
            // console.log($(':input').val());


            // 添加class
            // $('.container').addClass('c1 c2');
            // 移除class
            // $('.container').removeClass('c1');
            // 切换class
            // 如果当前存在,则移除,否则添加
            // 更多的情况用在动画的切换
            // $('.container').toggleClass('active');


            // 添加a标签
            // var a = $('<a></a>').appendTo('.container');
            // 设置内容
            // a.html('百度一下');
            // 添加属性
            // a.attr('href', 'http://www.baidu.com');
            // 添加class
            // a.addClass('link');

            // $('<a></a>').appendTo('.container').html('百度一下').attr('href', 'http://www.baidu.com').addClass('link');
            $('<a></a>').html('百度一下').attr('href', 'http://www.baidu.com').addClass('link').appendTo('.container');


            // 如果attr方法,只有一个参数,为属性名,则获取对应的属性值
            $('.link').attr('href');
            // 如果attr方法,有两个参数,分别为名称值,为修改或添加属性值
            $('.link').attr('href', 'http://blog.lidaze.com');
            // 如果attr方法有一个参数,并且为对象,则可以同时添加或修改多个属性与其对应的值
            $('.link').attr({
                href: 'http://book.lidaze.com',
                title: '我是a标签'
            });
            // 移除
            $('.link').removeAttr('title');



            // css()方法和attr()方法使用几乎一样
            // css()赋值标签的样式
            $('.link').css('color');
            $('.link').css('color', 'yellow');
            $('.link').css({
                color: 'green',
                'font-size': '30px'
            });

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

推荐阅读更多精彩内容

  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,155评论 0 1
  • 原文链接 http://blog.poetries.top/2016/10/20/review-jQuery 关注...
    程序员poetry阅读 16,634评论 18 503
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,316评论 0 2
  • //------------------------- 第一章 认识JQuery ----------------...
    米塔塔阅读 698评论 0 9
  • 人无远虑,必有近忧。 这句话确实没错,但是请不要理解错了,这里的“虑”可不是焦虑的“虑”。 如果人没有对未来的美好...
    grey256阅读 300评论 0 0