JavaScript重点知识(二)
三.JS的API
3.1知识点(DOM)
1)DOM本质
- 将html结构化成浏览器和JS可识别可操作的东西
2)变量计算---强制类型转换
- 获取DOM节点
- Attribute(对html标签属性的修改)
- prototype(对JS对象的属性修改)
3)DOM结构操作
- 增加DOM节点 .appendChild( )
- 获取父元素 .parentElement
- 获取子元素 .childNode
- 删除节点 .removeChild( )
3.2知识点(BOM)
1)navigator
- .userAgent
2)screen
- .width
- .height
3)location
- .href
- .protocal
- .host
- .pathname
- search
- .hash
4)screen
- .back( )
- .forward( )
3.3知识点(事件绑定)
1)通用事件绑定
- .addEventlistener('事件',函数)
2)事件冒泡
- event.stopPropagation( )
3)取消默认
- event.preventDefault( )
4)代理
- var target = e.target
3.4知识点(Ajax)
1)XMLHttpRequest
var xhr = new XMLHttpRequest( );
xhr.onreadystatechange = function( ){
if(xhr.readyState==4){
if(xhr.status==200){
alert(xhr.responseText);
}
}
};
xhr.open("GET","/api",false);
xhr.send(null);
2)状态码说明
- 0-(未初始化)没调用send( )
- 1-(载入)调用send( ),正发送请求
- 2-(载入完成)send( )完,收完内容
- 3-(交互)解析响应内容
- 4-(完成)解析完可以在客户端用
- 2xx-成功处理请求
- 3xx-要重定向,浏览器直接跳转
- 4xx-客户端请求错误
- 5xx-服务端错误
3)跨域
- 什么是跨域
- 跨域条件:协议、域名、端口,有一个不同就算跨域
- 浏览器有同源策略,不允许ajax访问其他域接口
- 可以跨域的三个标签
- <img src = xxx>
- <link href = xxx>
- <script src = xxx>
3.5知识点(JSONP)
1)实现原理
- 加载某网址上的html文件http://www.xxxx.com/class.html
- 服务器端不一定有一个class.html文件,服务器可根据请求动态生成文件返回
2)例子
- 你要访问某网站的一个接口,该网站给你一个地址,你将它写在你的网站的<script src = xxx>里
- 同时,还要写一个window.callback = function(data){//我们跨域得到的信息}
3.6知识点(存储)
1)cookie
- 本身用于客户端和服务端通信,但有本地存储功能
- 用document.cookie = ...获取和修改
- 缺点:
- 存量小,4kb
- 所有http请求都带着,影响资源获取效率
2)locationStorage和sessionStorage
- html为存储设计,最大存储量5M
- API简单易用
- .setItem(key,value)
- .getItem(key)
3)三者区别
- 容量
- 是否携带到ajax中
- API易用性
关于JS重点知识介绍到这里,这里不作详细介绍,只粗略列出常用知识点。
JavaScript重点知识(二)的更多相关文章
- AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解
AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解 javascriptvue-clicommonjswebpackast 阅读约 27 分钟 抽象语法树(AST),是一 ...
- JavaScript重点知识(一)
一.总括 基础知识: 1.变量 2.原型和原型链 3.作用域和闭包 4.异步和单线程 JS的API: 1.BOM,DOM操作 2.事件绑定 3.Ajax 4.JSOP 5.存储 二.基础知识 2.1知 ...
- 【转载】STL"源码"剖析-重点知识总结
原文:STL"源码"剖析-重点知识总结 STL是C++重要的组件之一,大学时看过<STL源码剖析>这本书,这几天复习了一下,总结出以下LZ认为比较重要的知识点,内容有点 ...
- JavaScript基础笔记二
一.函数返回值1.什么是函数返回值 函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...
- 学习javascript基础知识系列第二节 - this用法
通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...
- 学习javascript基础知识系列第三节 - ()()用法
总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...
- javascript常用知识点集
javascript常用知识点集 目录结构 一.jquery源码中常见知识点 二.javascript中原型链常见的知识点 三.常用的方法集知识点 一.jquery源码中常见的知识点 1.string ...
- {Python之线程} 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Threading模块 九 锁 十 信号量 十一 事件Event 十二 条件Condition(了解) 十三 定时器
Python之线程 线程 本节目录 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Thr ...
- AJAX重点知识的心得体会
下面就为大家带来一篇 AJAX重点知识的心得体会.学习还是有点帮助的,给大家做个参考吧. AJAX是什么? 是Asynchronous Javascript And XML的首字母的缩写, 它不是一门 ...
随机推荐
- HDU 3461 Code Lock(并查集+二分求幂)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3461 A lock you use has a code system to be opened in ...
- UVA 11584 Partitioning by Palindromes (字符串区间dp)
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- how to backup your system of Autel MS908 Pro
how to backup your system of Autel Scan Tool Autel MS908 Pro: Connect the tablet to a PC desktop or ...
- zabbix实现电话、短信、邮件报警
该报警方式提前说明:(1)该方式可以实现zabbix免费电话报警以及微信.短信.邮件报警,但有数量限制.详见如下:如数量不能满足需要以及人员需要,可以考虑购买收费版.(2)毕竟是免费版,电话通知要省着 ...
- ogg 12.3 for sqlserver 2016 CDC模式配置
本文主要讲述ogg 12.3 通过CDC抽取sqlserver 2016 enterprise的过程,投递配置相对简单,所以不在此阐述. 配置步骤概述 1. 解压ogg 12.3 for sqlser ...
- 怎样从外网访问内网Lighttpd?
本地安装了一个Lighttpd,只能在局域网内访问,怎样从外网也能访问到本地的Lighttpd呢?本文将介绍具体的实现步骤. 准备工作 安装并启动Lighttpd 默认安装的Lighttpd端口是80 ...
- Source Insight 如何将script等文件加入
点击菜单栏Options -> Document Options , 然后再弹出的对话框中找到File filter,文件过滤的设置,里面肯能有*.c;*.h 你在后面添加Makefile,注意 ...
- linux shell习题
课件地址:https://wenku.baidu.com/view/bac2ff10f18583d0496459f3.html 1.测试环境变量:HOME,PWD,IFS等2.测试位置变量:$$,$# ...
- pycharm+PyQt5+python最新开发环境配置,踩坑过程详解
安装工具:Pycharm 专业版2017.3PyQT5python3 pyqt5-tools 设置扩展工具的参数找到setting->tools->external tools,点击加号新 ...
- OL6.3 设置本地yum源
仅在 Oracle Linux Server release 6.3 上测试 PS:Oracle Linux Server release 6.3仅用于测试,不能用于商业用途 [root@oracle ...