三.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重点知识(二)的更多相关文章

  1. AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解

    AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解 javascriptvue-clicommonjswebpackast  阅读约 27 分钟 抽象语法树(AST),是一 ...

  2. JavaScript重点知识(一)

    一.总括 基础知识: 1.变量 2.原型和原型链 3.作用域和闭包 4.异步和单线程 JS的API: 1.BOM,DOM操作 2.事件绑定 3.Ajax 4.JSOP 5.存储 二.基础知识 2.1知 ...

  3. 【转载】STL"源码"剖析-重点知识总结

    原文:STL"源码"剖析-重点知识总结 STL是C++重要的组件之一,大学时看过<STL源码剖析>这本书,这几天复习了一下,总结出以下LZ认为比较重要的知识点,内容有点 ...

  4. JavaScript基础笔记二

    一.函数返回值1.什么是函数返回值    函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...

  5. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  6. 学习javascript基础知识系列第三节 - ()()用法

    总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...

  7. javascript常用知识点集

    javascript常用知识点集 目录结构 一.jquery源码中常见知识点 二.javascript中原型链常见的知识点 三.常用的方法集知识点 一.jquery源码中常见的知识点 1.string ...

  8. {Python之线程} 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Threading模块 九 锁 十 信号量 十一 事件Event 十二 条件Condition(了解) 十三 定时器

    Python之线程 线程 本节目录 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Thr ...

  9. AJAX重点知识的心得体会

    下面就为大家带来一篇 AJAX重点知识的心得体会.学习还是有点帮助的,给大家做个参考吧. AJAX是什么? 是Asynchronous Javascript And XML的首字母的缩写, 它不是一门 ...

随机推荐

  1. 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 ...

  2. UVA 11584 Partitioning by Palindromes (字符串区间dp)

    题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...

  3. 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 ...

  4. zabbix实现电话、短信、邮件报警

    该报警方式提前说明:(1)该方式可以实现zabbix免费电话报警以及微信.短信.邮件报警,但有数量限制.详见如下:如数量不能满足需要以及人员需要,可以考虑购买收费版.(2)毕竟是免费版,电话通知要省着 ...

  5. ogg 12.3 for sqlserver 2016 CDC模式配置

    本文主要讲述ogg 12.3 通过CDC抽取sqlserver 2016 enterprise的过程,投递配置相对简单,所以不在此阐述. 配置步骤概述 1. 解压ogg 12.3 for sqlser ...

  6. 怎样从外网访问内网Lighttpd?

    本地安装了一个Lighttpd,只能在局域网内访问,怎样从外网也能访问到本地的Lighttpd呢?本文将介绍具体的实现步骤. 准备工作 安装并启动Lighttpd 默认安装的Lighttpd端口是80 ...

  7. Source Insight 如何将script等文件加入

    点击菜单栏Options -> Document Options , 然后再弹出的对话框中找到File filter,文件过滤的设置,里面肯能有*.c;*.h 你在后面添加Makefile,注意 ...

  8. linux shell习题

    课件地址:https://wenku.baidu.com/view/bac2ff10f18583d0496459f3.html 1.测试环境变量:HOME,PWD,IFS等2.测试位置变量:$$,$# ...

  9. pycharm+PyQt5+python最新开发环境配置,踩坑过程详解

    安装工具:Pycharm 专业版2017.3PyQT5python3 pyqt5-tools 设置扩展工具的参数找到setting->tools->external tools,点击加号新 ...

  10. OL6.3 设置本地yum源

    仅在 Oracle Linux Server release 6.3 上测试 PS:Oracle Linux Server release 6.3仅用于测试,不能用于商业用途 [root@oracle ...