码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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>

    结果:

     

  • 相关阅读:
    鸿蒙服务卡片开发总结
    MT1184矩形相交 题解【超详细】
    无线设备的天线怎么安装最好?
    OneOS基于 LVGL 移植轻量化图形组件
    About 8.21 This Week
    安装极狐GitLab Runner并测试使用
    GPT-4 等大语言模型(LLM)如何彻底改变客户服务
    表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
    腾讯云轻量2核4G5M可容纳多少人访问?
    高级语言垃圾回收思路和如何减少性能影响原理分析
  • 原文地址:https://blog.csdn.net/z_2532040197/article/details/126149219
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号