## 方法1
### 一个完整的ajax步骤:
1、创建ajax核心对象
2、与服务器建立连接
3、发送请求
4、响应
```
//easy-mock模拟一个get接口
var url = "https://www.easy-mock.com/mock/5bad8210a1b7f6239a61664f/pcTest";
//新建一个HTTP请求
var xhr = new XMLHttpRequest();
xhr.open("get", url);
xhr.send();//发送请求
xhr.onreadystatechange = function () {
//当请求成功时
if (xhr.readyState === 4 && xhr.status == 200) {
var reponse = xhr.responseText;
//JSON.parse()将字符串转为json对象
var name = JSON.parse(reponse).data.name;
console.log(name)
}
}
```
*****
## 方法2
记得导入jQuery
```
<div id="div"></div>
<img src="" alt="">
<script>
$.ajax({
url: "http://douban.uieee.com/v2/movie/top250",
dataType: "jsonp",
success: res => {
let subjects = res.subjects[0];
let { title, images } = subjects; //解构
$("#div").html(title)
$("img").attr("src", images.small)
console.log(res)
}
})
</script>
```
- HTML,CSS
- 如何书写高效的css样式
- box-shadow
- 表格合并行列
- 自适应单位
- 隐藏元素
- 浏览器缓存
- 浏览器内核
- css和js的合理走位
- 2021样式问题汇总
- 模拟面试
- 移动端适配问题
- flexible(rem)
- vw+rem
- 判断一个属性是对象的私有属性
- px rpx em rem vw
- 清除浮动
- 栅格系统
- get&&post
- 雪碧图
- new操作符
- call apply bind区别
- 前端模块化
- 回调函数
- 回调地狱(封装版)
- 回调地狱(promise)
- 回调地狱(generator)
- 回调地狱(async)
- es6新特性
- let
- 箭头函数
- 展开 解构 默认赋值
- vue生命周期
- axios封装
- axios跨域拿数据
- ajax封装
- JavaScript
- 数组
- 排序
- 取偶数
- 反转排序
- 取最大值
- 数组去重
- 复杂版
- 数组的克隆(深拷贝)的方法
- 求质数
- 原型和原型链
- 创建对象
- 什么是路由
- SASS
- jQuery中的append和prepend区别?
- css动画及js动画的区别
- 隐式类型转换
- 原型
- 事件传播
- 函数
- 增加属性
- 构造函数
- 一元操作符
- 作用域
- 短语
- Vue
- - nextTick
- 自我介绍
- 哦豁(;д;)
- for in效果
- 事件
- promise特点
- 如何实现一个ajax请求
- 媒体查询
- substr和substring
- MVC、MVVM
- 面向对象
- 取数据、渲染数据
- ajax
- vue
- React
- es6-class
- 几种类型的DOM节点
- js同源策略
- 闭包
- 2021
- 数据类型
- 闭包2
- 防抖节流
- 原型与原型链
- call与apply与bind
- 深浅拷贝
- New关键字
