通常用于在网站上表示和传输数据

使用JavaScript处理JSON的所有工作,包括访问JSON对象中的数据项并编写自己的JSON。

JSON text基本上就像是一个JavaScript对象,这句话几乎是正确的。

原因就是,例外见下:

Arrays 也是一个 JSON对象.

其他:

  • JSON是纯数据格式,只有属性,没有方法
  • JSON要求两边有括号{}/[]
  • 不像JavaScript标志符可以用做属性,在JSON中,属性必须是quoted strings。
  • JSON格式验证器 :  https://jsonlint.com/

我的code pen:

例:https://codepen.io/chentianwei411/pen/mGadJX

重点:

1。使用XML方式发送请求并处理响应。Rails.ajax({})是用xml写的。

需要4个方面:

  1. url
  2. type
  3. data  , get就不需要了。
  4. dataType, 响应的数据格式。
  1. var request = new XMLHttpRequest();
  2. request.open("GET", requestURL)      //type, url
  3. request.responseType = 'json'       //dataType
  4. request.send()
  5.  
  6. request.onload = function() {       //success函数内把数据插入DOM。
  7. var superHeroes = request.response;
  8. populateHeader(superHeroes);    //2个方法createElement,添加textContent, 插入DOM.
  9. showHeroes(superHeroes);
  10. }

2

JSON.parse(): 把收到的字符串转化为javascript对象。

JSON.stringify(): 正相反,把js对象转化为JSON字符串。 Rails用 as_json()/to_json()

  1. var myJSON = { "name" : "Chris", "age" : "38" };
  2. var myString = JSON.stringify(myJSON);
  3. myString =>
  4. "{"name":"Chris","age":"38"}"

知识点:

  1. section article {
  2. width: 33%;
  3. float: left;
  4. }
  5.  
  6. 1. session article {} 选择所有在session中的article
    2. width配合float,横向排列。

学习了一个案例:

我的code pen:

https://codepen.io/chentianwei411/pen/qMvEJK

挑战:  添加一个evil circle 尚未做。


Event Object

所有事件的对象都基于Event Object,

  • DragEvent,
  • keyboardEvent,
  • MouseEvent。
  • 等等。
  • 还可以自定义event,使用createEvent()方法,内部参数很多。

MouseEvent

有大量的properties 和 methods:

如button就是一个特性,当鼠标事件被激活时,返回鼠标点击的按钮(左/轮/右)。

有多个event type类型:

onclick, onmousedown等等。

事件是对象,也就可以当参数传递

例子,参数e代表了click 事件对象。

click事件对象,继承了Event对象的部分特性和部分方法,因此可以使用如target, type, timeStamp方法。

  1. 这里targetEvent对象的方法,委托给click事件对象使用。
  2.  
  3. function bgChange(e) {
  4. var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
  5. e.target.style.backgroundColor = rndCol;
  6. }
  7.  
  8. btn.addEventListener('click', bgChange);

例子-我的code pen改变颜色:用addEventListener(),和onclick事件。


event.preventDefault()

防止元素的默认事件行为。

  • 比如点击表单按钮,可以通过preventDefault()停止提交表单行为,然后自定义。
  • 点击一个<a href='https://w3schools.com/'>,停止导向它指向的URL。

capture and bubbling

使用stopPropagation()   (点击看code pen案例)

用于停止事件传播event flow, 防止在冒泡或捕捉中,相同的事件被调用。

解释:当元素自身的事件执行后,开始冒泡,或捕捉,这个方法就是在冒泡或捕捉中遇到相同的事件后,停止这个事件的执行。

还有一个变种,stopimmediatePropagation(),  假设元素自身有两个click事件,只会执行第一个,同样有防止在冒泡或捕捉中,相同的事件被调用的功能。

事件委托技巧: 利用事件的冒泡bubble行为。 (点击查看code pen上的案例)

设计:

当<父元素>内有一堆子元素都有相同的event并有相同的运行代码时,可以在<父元素> 上设定addEventListener('一个事件', function(){ ... })监听这个事件。子元素上无需再写任何event代码。

操作:

当用户在子元素上的操作,触发某个event后(自身没有代码可以运行), bubbling,父元素上监听到这个event,执行代码。


Gallary:

一个练习,用到if, for语法, 方法:addEventListener(), setAttribute(), getAttribute()。

css:

postion: relative/absolute

解释: 分别用到父元素和子元素中,子元素的位置根据父元素来变化。

我的code pen:

https://codepen.io/chentianwei411/pen/GXeVjG


JS-Object (3) JSON; Event Object相关知识(事件冒泡,事件监听, stopPropagation()的更多相关文章

  1. 理解js事件冒泡事件委托事件捕获

    js事件冒泡 javascript的事件传播过程中,当事件在一个元素上出发之后,事件会逐级传播给先辈元素,直到document为止,有的浏览器可能到window为止,这就是事件冒泡现象. <di ...

  2. vue.js之过滤器,自定义指令,自定义键盘信息以及监听数据变化

    一.监听数据变化 1.监听数据变化有两种,深度和浅度,形式如下: vm.$watch(name,fnCb); //浅度 vm.$watch(name,fnCb,{deep:true}); //深度监视 ...

  3. js原生子级元素阻止父级元素冒泡事件

    <html> <head> <style type="text/css"> #hide{ width:75%;height:80px;backg ...

  4. js实现F5键刷新后菜单保持之前状态以及监听F5页面刷新子iframe 而父页面不刷新

    利用layui实现菜单效果时,刷新页面仍回到首页状态,需要 实现iframe子页面刷新父元素不刷新,下面是代码 //刷新时禁用F5的默认事件 $(document).keydown(function ...

  5. vue.js 跳转同一页面,传不同值,组件监听路由

    watch: { '$route' () { this.type = this.$route.params.type this.loadData() } },

  6. js --- 事件冒泡 事件捕获

    先上结论: 他们是描述事件触发时序问题的术语.事件捕获指的是从document到触发事件的那个节点,即自上而下的去触发事件.相反的,事件冒泡是自下而上的去触发事件.绑定事件方法的第三个参数,就是控制事 ...

  7. Vue.js 相关知识(基础)

    1. Vue.js 介绍 Vue,读音 /vjuː/,类似于 view),是一套用于构建用户界面的渐进式框架(重点在于视图层). 作者:尤雨溪 注:学习 vue.js 时,一定要抛弃 jQuery 的 ...

  8. listener监听器的相关知识

    从别人的博客上我学习了listener的相关知识现在分享给大家 1.概念: 监听器就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上 ...

  9. Linux Epoll相关知识

    其实在Linux下设计并发网络程序,向来不缺少方法,比如典型的Apache模型(Process Per Connection,简称PPC),TPC(Thread PerConnection)模型,以及 ...

随机推荐

  1. TestDriven.NET 怎么设置快捷键keyboard shortcut(转)

    TestDriven.NET 怎么设置快捷键keyboard shortcut 使用TestDriven.NET 测试的时候,觉得点击鼠标很麻烦是不是?嗯,我也觉得,那么我们来看看怎么设置它的快捷键把 ...

  2. 【百度统计】设置页面元素点击事件转化pv、uv

    html元素点击事件内添加代码:_hmt.push(['_trackEvent', category, action, opt_label, opt_value]); 1. '_trackEvent' ...

  3. JavaScript中hoisting(悬置/置顶解析/预解析) 实例解释,全局对象,隐含的全局概念

    JavaScript中hoisting(悬置/置顶解析/预解析) 实例解释,全局对象,隐含的全局概念 <html> <body> <script type="t ...

  4. java.lang.NoClassDefFoundError: org/apache/http/client/config/RequestConfig

    java 错误.java.lang.NoClassDefFoundError: org/apache/http/client/config/RequestConfig 本质上是httpClient的j ...

  5. 代码静态扫描工具sonar

    一.SonarQube整体介绍 SonarQube为静态代码检查工具,采用B/S架构,帮助检查代码缺陷,改善代码质量,提高开发速度,通过插件形式,可以支持Java.C.C++.JavaScripe等等 ...

  6. Google's Machine Learning Crash Course #03# Reducing Loss

    Goal of training a model is to find a set of weights and biases that have low loss, on average, acro ...

  7. python网络编程之一

    套接字的详细介绍会在另一篇博文指出,此片博文主要是python套接字的简单客户端编写. 两种套接字介绍: 面向连接的套接字:面向连接的套接字提供序列化,可靠的和不重复的数据交付.面向连接是可靠的传输, ...

  8. SQL学习之简单增删改查

    SQL最常用的语句,就是增删改查: 增删改查的对象,分别是库(文件夹),表(文件),表的内容(表的记录): 一.创建一个基本的表 #create table Student_Info (Name VA ...

  9. vc编辑器常用设置

    代码格式化 1.选中代码: 2.ctrl+K: 3.ctrl+F; 显示行号

  10. FTP-IIS Web

    快速搭建一个本地的FTP服务器   如果需要开发FTP文件上传下载功能,那么需要在本机上搭建一个本地FTP服务器,方便调试. 第一步:配置IIS Web服务器 1.1 控制面板中找到“程序”并打开 1 ...