三.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. [转载]SQL中EXISTS的用法

    比如在Northwind数据库中有一个查询为SELECT c.CustomerId,CompanyName FROM Customers cWHERE EXISTS(SELECT OrderID FR ...

  2. QT多线程简单例子

    在Qt中实现多线程,除了使用全局变量.还可以使用信号/槽机制. 以下例子使用信号/槽机制. 功能: 在主线程A界面上点击按钮,然后对应开起一个线程B.线程B往线程A发送一个字符串,线程A打印出来. 1 ...

  3. Tensorflow学习笔记03-使用神经网络做线性回归

    import tensorflow as tf import numpy as np #input就是输入数据,输入矩阵,in_size就是输入矩阵的列数(数据属性数量),out_size输出矩阵列数 ...

  4. django模板-通过a标签生成链接并跳转

    views.py from django.shortcuts import render from django.http import HttpResponse def index(request) ...

  5. netstat -ano输出中的ESTABLISHED off

    今天,我们性能测试的环境出现个奇怪现象,通过oci direct load回库的进程似乎僵死了,应用端cpu 200%(两个线程在跑,一个是一直在ocidirectload没反应,另外一个是正在sem ...

  6. tomcat报java.lang.VerifyError错误

    google结果: 针对“java.lang.VerifyError”的错误原因,主要是因为jar包的版本问题导致,可能是因为部署环境存在2套以上版本冲突的JDBC驱动程序部署在应用服务器不同的lib ...

  7. 复选框批量删除操作-jquery方式

    1.首先在页面添加一个批量删除的按钮:<li class="btns"><input id="deleteSubmit" class=&quo ...

  8. topcoder srm 688 div1 -3

    1.给出一个只包含'(',')'的字符串$s$,现在对它进行若干次如下操作使其变成匹配的括号串(每次操作包含3个步骤):(1)选择 $L,R,L\leq R$;(2)将$L,R$之间的字符翻转:(3) ...

  9. if语句学习

    #print("您好,我叫周星驰") ''' x=1+2+3 print(x*4) print(x**x) a=input("请输入相应的数字a") a=int ...

  10. Python3基础 list [] 创建空列表

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...