三.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. web前端利用leaflet生成粒子风场,类似windy

    wind.js如下: $(function() { var dixing = L.tileLayer.chinaProvider('Google.Satellite.Map', { maxZoom: ...

  2. Codeforces 237A - Free Cash

    题目链接:http://codeforces.com/problemset/problem/237/A Valera runs a 24/7 fast food cafe. He magically ...

  3. bzoj4358 premu

    题目链接 莫队算法 没有用线段树,而是看了showson的并查集%%% #include<algorithm> #include<iostream> #include<c ...

  4. 10分钟看懂!基于Zookeeper的分布式锁

    实现分布式锁目前有三种流行方案,分别为基于数据库.Redis.Zookeeper的方案,其中前两种方案网络上有很多资料可以参考,本文不做展开.我们来看下使用Zookeeper如何实现分布式锁. 什么是 ...

  5. @RefreshScope 的作用

    让在application.properties里自定义的变量也能通过@Value 注解正常注入

  6. Server Library [Apache Tomcat 7.0] unbound解决方案

    问题描述: 当在MyEclipse中导入高版本Eclipse的[Eclipse Dynamic Web]项目后,会发现其Java Build Path(选定项目->Alt+Enter即可打开Pr ...

  7. mysql/mariadb应该使用utf8mb4而不是utf8

    详情参考https://mp.weixin.qq.com/s?__biz=MzIwMzg1ODcwMw==&mid=2247487968&idx=1&sn=2ff7b511f6 ...

  8. py4CV例子3Mnist识别和ANN

    1.什么是mnist数据集:  , , ], ,,,,,,,,]], ., ., , , ], ,,,,,,,,]], ., ., , , ])) animals_net.setTermCriteri ...

  9. NOIP 2016 换教室 (luogu 1850 & uoj 262) - 概率与期望 - 动态规划

    题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n2n 节课程安排在 nn 个时间段上.在第 ii(1 \leq i \leq n1≤ ...

  10. Junit中AssertTrue的使用

    assertTrue public static void assertTrue(String message, boolean condition) Asserts that a condition ...