当前位置: 首页 > wzjs >正文

赶集网站建设多少钱搜索引擎优化怎么做的

赶集网站建设多少钱,搜索引擎优化怎么做的,产品展示类网站模板,赤峰做企业网站公司Axios 1. Axios 和 Ajax 简介2. Axios 和 Ajax 的区别3. 从 按钮 到 Axios请求后端接口的 大致顺序 1. Axios 和 Ajax 简介 Ajax(Asynchronous JavaScript and XML) 不是一种技术,而是一个编程技术概念,核心是通过 XMLHttpReques…

Axios

    • 1. Axios 和 Ajax 简介
    • 2. Axios 和 Ajax 的区别
    • 3. 从 按钮 到 Axios请求后端接口的 大致顺序

1. Axios 和 Ajax 简介

Ajax(Asynchronous JavaScript and XML) 不是一种技术,而是一个编程技术概念,核心是通过 XMLHttpRequest 对象实现异步通信。

Axios 是一个独立的库,它既在浏览器环境中使用了 XMLHttpRequest,又在服务端使用 原生node.js http 模块。

2. Axios 和 Ajax 的区别

特性原生 Ajax(XMLHttpRequest)Axios
使用方式需要手动创建 和 管理 XMLHttpRequest 对象提供简洁的 API,如 axios.get()axios.post()
异步处理使用回调函数基于 Promise,支持 async/await
功能扩展功能有限,需手动实现内置拦截器、请求取消、自动转换 JSON 等功能
跨平台支持仅限浏览器支持浏览器和 Node.js

3. 从 按钮 到 Axios请求后端接口的 大致顺序

  1. 点击按钮
    点击按钮时,触发 @click 点击事件,就到了 login 函数。

    在这里插入图片描述

    <!-- 登录按钮 -->
    <el-form-item><el-button class="button" type="primary" auto-insert-space @click="login">登录</el-button>
    </el-form-item>
    
  2. login里请求接口的函数,写在了 user.js 文件中
    Login.vue

    示例代码

    import { userLoginService } from '@/api/user.js'
    import { ElMessage } from 'element-plus'//导入路由 router
    import {useRouter} from 'vue-router'
    const router = useRouter();//导入 有Pinia函数的token.js文件
    import { useTokenStore } from '@/stores/token'
    const tokenStore = useTokenStore();//登录函数 login
    const login = async () => {//调用接口,完成登录let result = await userLoginService(registerData.value);//alert(result.msg ? result.msg : '登录成功');ElMessage.success(result.msg ? result.mag : '登录成功');//把得到的token存储到pinia中tokenStore.setToken(result.data);//跳转到首页,使用useRouter切换组件,完成跳转router.push('/');
    }
    
  3. user.js 里的请求,都统一用 request.js 请求工具来完成
    在这里插入图片描述
    示例代码

    //导入request.js请求工具
    import request from '@/utils/request.js'//提供调用主次接口的函数
    export const userRegisterService = (registerData) => {//借助于UrlSearchParams完成传递const params = new URLSearchParams();for (let key in registerData) {params.append(key, registerData[key]);}return request.post('/user/register', params);
    }export const userLoginService = (loginData) => {const params = new URLSearchParams();for (let key in loginData) {params.append(key, loginData[key])}return request.post('/user/login', params);
    }
    
  4. 在请求工具 request.js 里,导入了Axios,并创建了请求拦截器响应拦截器
    有了拦截器,就可以在 请求服务前得到响应后 统一处理数据。
    在这里插入图片描述

    示例代码:

    //这里边相当于请求的工具,用来定制请求的实例//导入axios: npm install axios
    import axios from 'axios';//导入Message消息提示
    import { ElMessage } from 'element-plus';//定义一个变量,记录公共的前缀,baseURL
    // const baseURL = 'http://localhost:8080';
    // 这里的'/api'只是给后台访问的请求路径添加一个标识
    const baseURL = '/api';/*  axios.create()方法,把baseURL作为参数传入,该方法返回一个请求的实例instance,以后发送请求时,就不用axios.get了,直接用instance.get就可以 */
    const instance = axios.create({ baseURL })/* axios提供的拦截器,在请求或响应,被then或catch处理前拦截也就是在请求发出之前,有一个请求拦截器或在响应到达之前,有一个响应拦截器 *///导入Pinia
    import { useTokenStore } from '@/stores/token';
    //添加请求拦截器
    instance.interceptors.request.use((config) => {//请求前的回调const tokenStore = useTokenStore();//在pinia中定义的响应式数据,都不需要.valueif (tokenStore.token) {config.headers.Authorization = tokenStore.token;}return config},(err) => {//请求错误的回调Promise.reject(err);}
    )/* 由于模块加载的顺序,不能这样导入import { useRoute } from 'vue-router';const router = useRoute(); 
    */
    //这样导入就能用了
    import router from '@/router'//添加响应拦截器(这个拦截器本身就是异步的)
    instance.interceptors.response.use(//成功的回调result => {//判断业务状态码if (result.data.code === 0) {return result.data;}//操作失败ElMessage.error(result.data.msg ? result.data.msg : '服务异常');//异步操作的状态转换为失败return Promise.reject(result.data);},//失败的回调err => {//判断响应状态码,若为401,则说明未登录,提示请登录,并跳转到登录页面if(err.response.status === 401){ElMessage.error('请先登录');router.push('/login');}else{ElMessage.error('服务异常');}//异步的状态转化成失败的状态return Promise.reject(err);}
    )//把请求的实例instance导出,供其他地方调用
    export default instance;
    

    上述代码中的 const baseURL = ‘/api’,在另一篇文章 vue处理跨域问题 里有详细描述。

http://www.dtcms.com/wzjs/83001.html

相关文章:

  • 图书类网站建设策划书河南品牌网站建设
  • 网站开发的晋升晋升空间路径竞价推广开户公司
  • 阿里巴巴官网首页电脑版福州seo视频
  • asp access网站建设源代码360网站推广怎么做
  • 企业网站建设作用16888精品货源入口
  • 西安在线网站制作怎么安装百度
  • dw如何做网站后台天津网站建设
  • 批量建站怎么赚钱网站建设解决方案
  • 网站建设链接万能搜索引擎入口
  • wdcp上传网站搜索引擎优化方法包括
  • 都江堰网站建设培训上海关键词排名推广
  • 做类似淘宝一样的网站有哪些宁波seo外包服务商
  • 网站建设成本预算媒体邀约
  • 网站地图后缀友情链接如何交换
  • 最新聊天记录做图网站口碑营销有哪些方式
  • 美国做礼品的网站购买网站域名
  • 网站建设需要提供功能目录吗seo标题优化关键词
  • 桓台响应式网站建设网站加速器
  • 不锈钢餐具做外贸哪个网站好谷歌浏览器引擎入口
  • 悬赏做海报的网站360竞价推广客服电话
  • 大概开发一个网站多少钱新产品宣传推广策划方案
  • 石家庄大型网络公司宁波网站排名优化seo
  • 扬州建设工程信息网站关键信息基础设施安全保护条例
  • 网站建设的客户在哪里网站优化企业排名
  • 廊坊建设网站沧州网络推广公司
  • 做网站哪个便宜杭州百度推广电话
  • 建筑模板多少钱一块手机优化
  • 网站建设花多少钱智能网站推广优化
  • 云南昆明网站建设公司香飘飘奶茶软文
  • 沈阳设计网站公司哪家好广告策划