视频来源:麦子学院  讲师:魏畅然

补充:JSON.stringify()函数 【https://www.cnblogs.com/damonlan/archive/2012/03/13/2394787.html】 用来将对象序列化,也就是将对象转换为json字符串,例如

    var obj={};
obj.name='yolo';
obj.age=22;
console.log(obj);//输出: "[object Object]"
obj=JSON.stringify(obj);
console.log(typeof obj);//输出: "string"
console.log(obj);//输出:"{"name":"yolo","age":22}   
    console.log(JSON.stringify($('p').css('background','lightgreen')));
    //报错:"Uncaught TypeError: Converting circular structure to JSON"
    原因:发生了递归引用关系,如果一个json中的结构是a包含b,b包含c,c包含a,就无法执行toJSON方法
    因为我的代码是设置背景啊
    改为获取,$('p').css(['color','background']);
    
            $('p').css({
            background:'green',
            'font-size':'30px',//有中横线的话一定要用引号括起来
        })

一、选择器 

$('li:not(li:first)').css('background','yellow');
$('li:odd').css('background','yellow');
$('li:lt(2)').css();//lt小于,基本过滤选择器索引值从0开始
$('li:nth-child(2)').css();//子元素过滤选择器索引从1开始
$('div:contains(理想)').css('background','yellow'); 选取div中含有文本内容包含理想元素
:empty 选择内容为空&&没有子元素
:parent 选择内容不为空||含有子元素
:contains(text) 选择含有text文本的元素
:has(p) 选择含有p元素的元素
$('[type]').css('background','red'); 选择含有type属性的元素
$('[value^=input]').css('background','red');
$('li:first-child')范围比$('li:first')广
$('li:nth-child(2)').css();
$('li:only-child').css('background','yellow');只有唯一子元素的元素
$('p:only-child').css('background','yellow');选中作为唯一子元素存在的p元素

二、DOM操作

  1. 设置或者获取内容 - html(),text() val()
                $('div').html(function(index,html){
    alert(index+html)
    }) 遍历回调函数,索引从0开始
  2. 获取,设置属性 - attr(),removeAttr()

    <div id="div2"  data-id="data-id2">  data-id是自定义属性
    css代码: div[data-id="data-id2"]{background: orange;} <p class="p1 orange">div1-p1</p> 多个类是用空格分开的
    $('p[data-id]').attr('data-id','red'); 选取含有data-id属性的p元素,再将data-id属性值设为red
         //同时设置多种属性
    $('p[data-id]').attr({
    'data-id':'red',
    'class':'p2'
    });
  3. 类相关操作: addClass(),removeClass(),hasClass(),toggleClass()
  4. 设置样式  - css()
    $('p').css({
    background:'green',
    'font-size':'30px',//有中横线的话一定要用引号括起来
    }) $('p:first').css({
    background:'green',
    'font-size':function(index,val){
    alert(val);//返回原来的字体大小
    return val='30px';//用return 重新设置
    }
    })
  5. 元素内添加:append,prepend(appendTo,prependTo)
     元素外添加:after,before(insertAfter,insertBefore)
            $('#a').append($('p'));//喔噢,还以为append是复制粘贴,原来是直接把原元素剪切到指定位置去
    $('#a').prepend('<p>内部前面</p>');
    $('#a').after('<p>外部后面</p>');
    $('#a').before('<p>外部前面</p>');
  6. remove删除整个元素 ,detach与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。
     empty()清空内容
            var e=$('p').remove();//remove()返回移除的元素
    $('#a').append(e);
  7. wrapInner ,wrap,wrapAll
    unwrap() 方法删除被选元素的父元素
    1、$('p').wrapInner('<b></b>');
    输出:<p><b>第一段</b></p> 2、$('p').wrap('<b></b>');
    输出:<b><p>第一段</p></b><b><p>第二段</p></b> 3、$('p').wrapAll('<b></b>');
    输出: <b>
    <p>第一段</p>
    <p>第二段</p>
    </b>
  8. replaceWith() 方法用指定的 HTML 内容或元素替换被选元素。(replaceAll)
        $('p').replaceWith('<div>I am not a paragraph anymore</div>');
    等价于:
    $('<div>I am not a paragraph anymore</div>').replaceAll($('p'));
  9. clone()
            $('p:first').before($('p:last'));//这是把第二段剪切到第一段之前
    $('p:first').before($('p:last').clone());//这是把第二段先进行复制,再粘贴到第一段之前

三、事件

  1. 优先级:mousedown>mouseup>click,所以这里只执行mousedown事件

            $('#div1').on('mousedown',function(){
    alert('mousedown now!');
    });
    $('#div1').on('mouseup',function(){
    alert('mouseup now!');
    });
    $('#div1').on('click',function(){
    alert('click now!');
    });
  2. keydown,keyup,keypress (http://blog.csdn.net/z69183787/article/details/25700837
        <p>当您在下面的框中键入文本时,会弹出键位序号。</p>
    <input type="text" placeholder="请随意键入字符……" /> <script type="text/javascript">
    $('input').keydown(function(event){
    alert(event.which);
    }) ,就是在左侧输入,右侧同步显示的过程中很有用处。典型的例子就是邮件编辑预览的应用。
    <script type="text/javascript">
    $('input').keyup(function(event){
    $('#div1').html($(this).val());
    })
  3. $('#div1').off('click');  取消事件
  4. 动画
    动画
    1 基本动画:show(speed[,callback]),hide(),toggle();speed值 - normal,fast,slow,或者具体数值,不用带单位,默认毫秒数
    2 预制动画:slideDown(speed[,callback]),slideUp(),slideToggle(),fadeIn(),fandeOut(),fadeToggle(),
    fadeTo(),控制透明度$('#div1').fadeTo(100,0.2);
    3 自定义动画 animate(css,持续时间,速率,回调函数) setTimeout() 只执行 code 一次。
    如果要多次调用,请使用 setInterval() 或者让 code 自身再次调用 setTimeout()。
  5. load函数
    $('#div1').load("0.php",{name:'yolo'},function(){
    alert(23);});
  6. JSON.parse(jsonstr); //可以将json字符串转换成json对象
    JSON.stringify(jsonobj); //可以将json对象转换成json对符串
  7. 由JSON字符串转换为JSON对象
    方法一
    var str='{ "name": "John" }';//标准JSON字符串,外面单引号,里面双引号,反正错过来就运行不了
    var obj = jQuery.parseJSON(str)
    alert( obj.name);
    方法二
        var j='{"name":"sa","age":22}';
        j=eval('('+j+')')
        alert(j.name);
    方法三
      JSON.parse(jsonstr);
       
  8. ajax post实例
                $.ajax({
    type:'post',
    url:'0.php',
    data:{'a':1},
    dataType:'json',
    success:function(data){
    data=JSON.parse(data);//将标准json字符串解析对对象
    alert(data.name);
    },
    });

07_jquery入门第一天的更多相关文章

  1. JAVA入门第一季(mooc-笔记)

    笔记相关信息 /** * @subject <学习与创业>作业1 * @author 信管1142班 201411671210 赖俊杰 * @className <JAVA入门第一季 ...

  2. Asp.Net MVC3 简单入门第一季(三)详解Controller之Filter

    前言 前面两篇写的比较简单,刚开始写这个系列的时候我面向的对象是刚开始接触Asp.Net MVC的朋友,所以写的尽量简单.所以写的没多少技术含量.把这些技术总结出来,然后一简单的方式让更多的人很好的接 ...

  3. Asp.Net Web API 2(入门)第一课

    Asp.Net Web API 2(入门)第一课   前言 Http不仅仅服务于Web Pages.它也是一个创建展示服务和数据的API的强大平台.Http是简单的.灵活的.无处不在的.你能想象到几乎 ...

  4. ElasticSearch入门 第一篇:Windows下安装ElasticSearch

    这是ElasticSearch 2.4 版本系列的第一篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  5. Docker 入门 第一部分: 定位和设置

    目录 Docker 入门 第一部分: 定位和设置 Docker概念 镜像和容器 容器和虚拟机 准备你的Docker环境 测试 Docker 的版本 测试 Docker 安装 回顾 总结 Docker ...

  6. leetcode 入门第一题 4ms? 8ms? Two Sum

    今天开启leetcode 入门第一题 题意很简单,就是一个数组中求取两数之和等于目标数的一对儿下标 1.暴力 n^2 两个for循环遍历 用时0.1s 开外 代码就不用写了 2.二分 nlogn 我们 ...

  7. [MVC.NET] Asp.Net MVC3 简单入门第一季

    转自:http://www.cnblogs.com/fly_dragon/archive/2011/10/12/2208042.html 初识Asp.Net MVC2.0 初识Asp.Net MVC2 ...

  8. Django入门第一步:构建一个简单的Django项目

    Django入门第一步:构建一个简单的Django项目 1.简介 Django是一个功能完备的Python Web框架,可用于构建复杂的Web应用程序.在本文中,将通过示例跳入并学习Django.您将 ...

  9. JMeter入门 | 第一个并发测试

    JMeter入门 | 第一个并发测试 背景 近期我们组新来了一些新同事,之前从来没有用过JMeter做个并发测试,于是准备了一系列小教程去指引新同事,本章主要是新人入门体验教程,快速实现第一个接口并发 ...

随机推荐

  1. 在树莓派上编译安装golang环境

    请看我在掘金的文章

  2. Windows环境下在Oracle VM VirtualBOX下克隆虚拟机镜像

    1.定位到Vritualbox的安装目录 2.将安装好的.vdi文件复制一份到指定目录下 3.执行 VBoxManage internalcommands sethduuid F:\VirtualBo ...

  3. 看JQ时代过来的前端,如何转换思路用Vue打造选项卡组件

    前言 在Vue还未流行的时候,我们都是用JQuery来封装一个选项卡插件,如今Vue当道,让我们一起来看看从JQ时代过来的前端是如何转换思路,用数据驱动DOM的思想打造一个Vue选项卡组件. 接下来, ...

  4. SpringBoot(四)之thymeleaf的使用

    这篇文章将更加全面详细的介绍thymeleaf的使用.thymeleaf 是新一代的模板引擎,在spring4.0中推荐使用thymeleaf来做前端模版引擎. thymeleaf介绍 简单说, Th ...

  5. [51nod1206]Picture

    给你一坨矩形,问这些矩形组成的所有多边形的周长之和. 分别求竖着的边和横着的边. 离散化后线段树,维护当前行(或者列)有多少没在多边形里的,添加矩形就变成添加.删除线段. 每次加线段或删线段时累加一下 ...

  6. [bzoj2574] [Poi1999]Store-Keeper

    坑啊.. 膜了半天byvoid大爷的题解.https://www.byvoid.com/blog/poi-1999-mag/?replytocom=1335/ 一开始从人的位置bfs一波,看看能走到初 ...

  7. HDU1097-A hard puzzle-快速幂+取模

    快速幂: 代码: kuaisumi(ll a,ll b){      ll ans=;      while(b){          ==){              ans=ans*a;     ...

  8. flume1.8 Channel类型介绍(四)

    1. Flume Channel Channels是events在agent上进行的存储库.Source添加events,Sink移除events. 1.1 Memory Channel(内存Chan ...

  9. 机器学习笔记5-Tensorflow高级API之tf.estimator

    前言 本文接着上一篇继续来聊Tensorflow的接口,上一篇中用较低层的接口实现了线性模型,本篇中将用更高级的API--tf.estimator来改写线性模型. 还记得之前的文章<机器学习笔记 ...

  10. 试用最强Spark IDE--IDEA

    1.安装IntelliJ IDEA IDEA 全称 IntelliJ IDEA,是java语言开发的集成环境,IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助手.代码自动提示 ...