• axios 和 fetch


    axios

            介绍:        

    Axios,是一个基于promise [5]  的网络请求库,作用于node.js浏览器中,它是 isomorphic 的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生node.js http模块, 而在客户端 (浏览端) 则使用XMLHttpRequest。

            特点:

    • 从浏览器创建 XMLHttpRequests

    • 从 node.js 创建 http 请求

    • 支持 Promise API

    • 拦截请求和响应

    • 转换请求和响应数据

    • 取消请求

    • 自动转换JSON数据

    • 客户端支持防御XSRF

    使用axios需要先从网上获取它的地址信息;以字节跳动静态资源公共库为例,进入页面之后,直接搜索axios,然后找到目标版本,然后复制axios.js的地址

     之后将地址通过script标签引入html文件中,使用代码如下:

    1. <button onclick="fn()">axios-ajaxbutton>
    2. <script>
    3. function fn() {
    4. var url = "http://192.168.0.114:8081/ajax1"
    5. axios(url).then((res) => {
    6. console.log(res);
    7. })
    8. }
    9. script>

    index.js文件的代码为:

    1. var router = require("./router.js")
    2. router.get("/ajax1",function(req,res) {
    3. res.end('{"name":"xiaozhang","age":21}')
    4. })

    router.js文件代码为:

    1. var fs=require("fs")
    2. var url=require("url")
    3. var querysting=require("querystring")
    4. var mime=require("mime")
    5. let urls={}
    6. var http=require("http")
    7. let router=function(req,res){
    8. //这个函数每次用户访问时运行
    9. let pathname=url.parse(req.url).pathname
    10. fs.readFile(router.basepath+pathname,(err,data)=>{
    11. if(!err){
    12. res.setHeader("content-Type",mime.getType(pathname))
    13. res.end(data)
    14. }else{
    15. if(!urls[pathname]){res.end("404 not found-mymvc")}
    16. else{urls[pathname](req,res)}
    17. }
    18. })
    19. }
    20. router.static=function(path){
    21. this.basepath=path
    22. }
    23. router.get=function(url,cb){
    24. urls[url]=cb
    25. }
    26. router.basepath=__dirname+"/public"
    27. http.createServer(router).listen(8081)
    28. module.exports=router;

    结果为:

    fetch 

            fetch 是 XMLHttpRequest 的升级版,使用js脚本发出网络请求,但是与 XMLHttpRequest 不同的是,fetch 方式使用 Promise,相比 XMLHttpRequest 更加简洁。

            fetch是浏览提供的功能,因此不需要单独引入模块。

            fetch的使用代码如下:

    1. <script>
    2. function fn() {
    3. var url = "http://192.168.0.114:8081/ajax1"
    4. fetch(url).then((data) => {
    5. return data.json()
    6. })
    7. .then((result) => {
    8. console.log(result);
    9. })
    10. }
    11. script>

    结果:

     

  • 相关阅读:
    Vxlan网络和flannel记录
    《Solar Energy Materials and Solar Cells》期刊介绍(SCI 2区)
    职责链模式,非常容易被忽视的设计模式之一(设计模式与开发实践 P13)
    [论文分享] EnBinDiff: Identifying Data-Only Patches for Binaries
    删除两个字典中非公共的键和值
    9月3日,每日信息差
    swift使用swift-protobuf协议通讯,使用指北
    ​力扣解法汇总640-求解方程
    iris 鸢尾花数据集&画图
    一键汇总报告模型可能会需要修改的地方
  • 原文地址:https://blog.csdn.net/z_2532040197/article/details/126149219