【三十天精通Vue 3】第二十五天 Vue3 与 Axios 后端数据交互

news2024/10/2 6:38:18

请添加图片描述

✅创作者:陈书予
🎉个人主页:陈书予的个人主页
🍁陈书予的个人社区,欢迎你的加入: 陈书予的社区
🌟专栏地址: 三十天精通 Vue 3

文章目录

    • 引言
    • 一、Vue3 与 Axios 概述
    • 二、Axios 安装与基本使用
      • 2.1 安装 Axios
      • 2.2 发送 GET 请求
      • 2.3 发送 POST 请求
      • 2.4 发送 PUT 请求
      • 2.5 发送 DELETE 请求
    • 三、Vue3 中使用 Axios 获取数据
      • 3.1 使用 Axios 获取数据
      • 3.2 渲染数据
      • 3.3 处理错误
    • 四、Axios 配置项详解
      • 4.1 baseURL
      • 4.2 表头
      • 4.3 参数
      • 4.4超时
      • 4.5 withCredentials
      • 4.6 响应类型
      • 4.7 transformRequest 和 transformResponse
      • 4.8 xsrfCookieName 和 xsrfHeaderName
      • 4.9 验证状态
    • 五、Axios 拦截器详解
      • 5.1 请求拦截器
      • 5.2 响应拦截器
    • 六、Axios 并发请求详解
      • 6.1 同时发送多个请求
      • 6.2 执行顺序
    • 七、Axios 取消请求详解
      • 7.1 为什么需要取消请求
      • 7.2 取消请求的方法
      • 7.3 如何使用取消请求
    • 八、Axios 封装和实践
      • 8.1 封装 Axios
      • 8.2 实践案例

引言

Axios是一个流行的基于Promise的HTTP客户端,它可以在浏览器和Node.js中使用。Vue.js是一个流行的JavaScript框架,它提供了一套易于使用的API和工具来构建交互式UI。在Vue.js中使用Axios可以轻松地与服务器通信并获取数据。本篇文章将介绍如何在Vue3中使用Axios进行HTTP请求,并详细介绍Axios的安装、基本使用、配置项、拦截器、并发请求和取消请求。

一、Vue3 与 Axios 概述

Vue3是Vue.js的最新版本,它提供了一些新的功能和改进,例如Composition API、性能优化和TypeScript支持。Axios是一个流行的HTTP客户端,它提供了许多强大的功能,例如拦截器、并发请求和取消请求。Vue3和Axios可以很好地结合使用,以便在Vue3应用程序中轻松地进行HTTP请求和数据获取。

二、Axios 安装与基本使用

2.1 安装 Axios

在使用Axios之前,首先需要安装它。可以使用npm或yarn来安装Axios。在终端中运行以下命令:

npm install axios

yarn add axios

2.2 发送 GET 请求

使用Axios发送GET请求非常简单。可以使用Axios.get()方法来发送GET请求,并指定URL。例如,以下代码将使用Axios获取JSON数据:

import axios from 'axios';

axios.get('https://jsonplaceholder.typicode.com/todos')
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.log(error);
  });

2.3 发送 POST 请求

使用Axios发送POST请求也非常简单。可以使用Axios.post()方法来发送POST请求,并指定URL和要发送的数据。例如,以下代码将使用Axios将数据发送到服务器:

import axios from 'axios';

axios.post('https://jsonplaceholder.typicode.com/todos', {
    title: 'foo',
    completed: false
  })
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.log(error);
  });

2.4 发送 PUT 请求

使用Axios发送PUT请求也非常简单。可以使用Axios.put()方法来发送PUT请求,并指定URL和要发送的数据。例如,以下代码将使用Axios将数据更新到服务器:

import axios from 'axios';

axios.put('https://jsonplaceholder.typicode.com/todos/1', {
    title: 'foo',
    completed: true
  })
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.log(error);
  });

2.5 发送 DELETE 请求

使用Axios发送DELETE请求也非常简单。可以使用Axios.delete()方法来发送DELETE请求,并指定URL。例如,以下代码将使用Axios从服务器删除数据:

import axios from 'axios';

axios.delete('https://jsonplaceholder.typicode.com/todos/1')
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    console.log(error);
  });

三、Vue3 中使用 Axios 获取数据

3.1 使用 Axios 获取数据

在Vue3中使用Axios获取数据非常简单。可以使用Axios.get()方法来获取数据,并将其存储在Vue3组件的数据属性中。例如,以下代码将使用Axios获取JSON数据并将其存储在Vue3组件的todos数据属性中:

import axios from 'axios';
import { reactive } from 'vue';

export default {
  setup() {
    const state = reactive({
      todos: []
    });

    axios.get('https://jsonplaceholder.typicode.com/todos')
      .then(response => {
        state.todos = response.data;
      })
      .catch(error => {
        console.log(error);
      });

    return {
      state
    };
  }
};

3.2 渲染数据

获取数据后,可以在Vue3组件中使用数据属性来渲染数据。例如,以下代码将使用Vue3的v-for指令来渲染todos数据属性中的所有待办事项:

<template>
  <div>
    <ul>
      <li v-for="todo in state.todos" :key="todo.id">
        {{ todo.title }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  props: {
    state: Object
  }
};
</script>

3.3 处理错误

在使用Axios获取数据时,可能会出现错误。例如,服务器可能返回错误的响应代码或请求可能超时。为了处理这些错误,可以使用Axios的.catch()方法来捕获错误并采取相应的措施。例如,以下代码将使用Axios获取JSON数据,如果出现错误,则将错误记录在控制台中:

import axios from 'axios';
import { reactive } from 'vue';

export default {
  setup() {
    const state = reactive({
      todos: []
    });

    axios.get('https://jsonplaceholder.typicode.com/todos')
      .then(response => {
        state.todos = response.data;
      })
      .catch(error => {
        console.log(error);
      });

    return {
      state
    };
  }
};

四、Axios 配置项详解

Axios提供了许多配置项,可以根据需要进行配置。以下是Axios配置项的详细说明:

4.1 baseURL

baseURL是在发出请求时将自动添加到URL前面的基本URL。例如,如果将baseURL设置为https://api.example.com,则在发送请求时,Axios将自动将https://api.example.com添加到请求的URL前面。以下是如何设置baseURL:

axios.defaults.baseURL = 'https://api.example.com';

4.2 表头

headers是一个包含请求头的对象。以下是如何设置headers:

axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;

4.3 参数

params是一个包含请求参数的对象。以下是如何设置params:

axios.get('/user', {
  params: {
    ID: 12345
  }
})

4.4超时

timeout是请求超时的毫秒数。如果请求在超时时间内没有完成,则会被取消。以下是如何设置timeout:

axios.get('/user', {
  timeout: 1000
})

4.5 withCredentials

withCredentials是一个布尔值,用于指定是否发送凭据(例如cookie或授权标头)的标志。如果要发送凭据,则将其设置为true。以下是如何设置withCredentials:

axios.defaults.withCredentials = true;

4.6 响应类型

responseType是请求的响应类型。以下是如何设置responseType:

axios.get('/user', {
  responseType: 'json'
})

4.7 transformRequest 和 transformResponse

transformRequesttransformResponse 是两个配置项,它们的值是一个数组或者是一个函数。其中 transformRequest 允许你在将请求数据发送到服务器之前对其进行修改,这只适用于请求方法 putpostpatch。如果值是数组,则数组中的最后一个函数必须返回一个字符串或者一个 Buffer,否则将抛出一个错误。transformResponse 允许你在传递给 then/catch 前,修改响应数据。它也可以是一个数组或者是一个函数。如果值是数组,则数组中的每个函数都将被调用。

4.8 xsrfCookieName 和 xsrfHeaderName

xsrfCookieNamexsrfHeaderName 是用于防止跨站请求攻击(XSRF)的配置项。xsrfCookieName 表示存储 XSRF 令牌的 cookie 的名称,xsrfHeaderName 表示将 XSRF 令牌添加到 HTTP 头中的名称。默认情况下,Axios 将使用 XSRF-TOKEN 作为 cookie 的名称,并使用 X-XSRF-TOKEN 作为 HTTP 头的名称。

4.9 验证状态

validateStatus 是一个函数,用于确定是否应该解析响应。如果该函数返回 true,则解析响应,否则将拒绝响应。默认情况下,Axios 将解析所有响应。以下是一个示例:

axios.get('https://jsonplaceholder.typicode.com/todos', {
  validateStatus: function (status) {
    return status < 500; // Reject only if the status code is greater than or equal to 500
  }
})

这将拒绝所有状态码大于等于 500 的响应。

五、Axios 拦截器详解

Axios 提供了请求和响应拦截器,它们允许您在请求和响应被发送或接收之前,对它们进行拦截和修改。以下是拦截器的详细说明:

5.1 请求拦截器

请求拦截器允许您在请求被发送之前,对其进行拦截和修改。以下是一个示例:

axios.interceptors.request.use(function (config) {
  // Do something before request is sent
  config.headers['Authorization'] = 'Bearer ' + getToken();
  return config;
}, function (error) {
  // Do something with request error
  return Promise.reject(error);
});

在这个例子中,我们添加了一个请求拦截器,它将在每个请求上添加一个 Authorization 头。

5.2 响应拦截器

响应拦截器允许您在接收到响应之前,对其进行拦截和修改。以下是一个示例:

axios.interceptors.response.use(function (response) {
  // Do something with response data
  return response;
}, function (error) {
  // Do something with response error
  return Promise.reject(error);
});

在这个例子中,我们添加了一个响应拦截器,它将在每个响应上执行一些操作。

六、Axios 并发请求详解

6.1 同时发送多个请求

Axios提供了axios.all()axios.spread()两个方法用于处理并发请求,可以实现在多个请求都完成后再执行一些逻辑。

axios.all()方法接收一个可迭代的对象作为参数,该对象中的每个元素都是一个Promise对象,返回一个新的Promise对象,当所有Promise对象都成功时,新的Promise对象才会成功。

例如,以下代码同时发送两个GET请求,当两个请求都成功时,输出两个请求的响应数据:

axios.all([
  axios.get('https://jsonplaceholder.typicode.com/todos/1'),
  axios.get('https://jsonplaceholder.typicode.com/todos/2')
])
  .then(axios.spread((response1, response2) => {
    console.log(response1.data);
    console.log(response2.data);
  }))
  .catch(error => {
    console.log(error);
  });

axios.spread()方法接收一个回调函数作为参数,该函数的参数是一个数组,数组中的每个元素是一个请求的响应数据。在axios.all()方法的then()方法中使用axios.spread()方法可以将响应数据拆分开来,方便处理。

6.2 执行顺序

在并发请求中,Axios默认使用的是同时发送多个请求的方式,而不是按照发送请求的顺序依次发送请求。

如果需要按照发送请求的顺序依次发送请求,可以使用axios.all()方法的返回值按顺序处理请求的响应数据。例如,以下代码按照发送请求的顺序依次输出响应数据:

axios.all([
  axios.get('https://jsonplaceholder.typicode.com/todos/1'),
  axios.get('https://jsonplaceholder.typicode.com/todos/2')
])
  .then(responses => {
    responses.forEach(response => {
      console.log(response.data);
    });
  })
  .catch(error => {
    console.log(error);
  });

七、Axios 取消请求详解

7.1 为什么需要取消请求

在实际开发中,有时需要取消正在进行的请求,例如用户在输入框中连续输入,每次输入都会发送一个请求,如果不及时取消之前的请求,会导致请求过多,浪费网络资源和服务器资源。

7.2 取消请求的方法

Axios提供了CancelTokencancel两个方法用于取消请求。CancelToken是一个工厂函数,用于创建取消令牌,cancel方法用于取消请求。

以下是使用CancelTokencancel方法取消请求的示例代码:

import axios from 'axios';

const source = axios.CancelToken.source();

axios.get('https://jsonplaceholder.typicode.com/todos', {
  cancelToken: source.token
})
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    if (axios.isCancel(error)) {
      console.log('Request canceled', error.message);
    } else {
      console.log(error);
    }
  });

source.cancel('Canceled by the user');

在以上代码中,使用axios.CancelToken.source()方法创建一个CancelToken对象和一个cancel方法。将CancelToken对象的token属性作为请求的cancelToken参数,当需要取消请求时,调用cancel方法即可。

7.3 如何使用取消请求

在实际开发中,有时需要取消正在进行的请求,例如用户在输入框中连续输入,每次输入都会发送一个请求,如果不及时取消之前的请求,会导致请求过多,浪费网络资源和服务器资源。Axios提供了CancelTokencancel两个方法用于取消请求。

以下是使用CancelTokencancel方法取消请求的示例代码:

  1. 创建CancelToken对象和cancel方法:

    const source = axios.CancelToken.source();
    
  2. CancelToken对象的token属性作为请求的cancelToken参数:

    axios.get('https://jsonplaceholder.typicode.com/todos', {
      cancelToken: source.token
    })
    
  3. 当需要取消请求时,调用cancel方法:

    source.cancel('Canceled by the user');
    

完整的代码示例:

import axios from 'axios';

const source = axios.CancelToken.source();

axios.get('https://jsonplaceholder.typicode.com/todos', {
  cancelToken: source.token
})
  .then(response => {
    console.log(response.data);
  })
  .catch(error => {
    if (axios.isCancel(error)) {
      console.log('Request canceled', error.message);
    } else {
      console.log(error);
    }
  });

source.cancel('Canceled by the user');

在上面的代码中,使用axios.isCancel(error)方法判断请求是否被取消,并输出相应的信息。

需要注意的是,在使用CancelTokencancel方法取消请求时,需要在请求发送前调用source.token,否则会抛出一个未定义的错误。同时,需要在请求结束后,取消CancelToken对象和cancel方法的引用,以避免内存泄漏。

八、Axios 封装和实践

8.1 封装 Axios

在实际项目中,我们通常需要对 Axios 进行封装,以便于统一处理请求的错误、请求头、请求参数等信息,同时也方便后期维护和更新。

以下是一个简单的 Axios 封装示例:

import axios from 'axios';

const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000
});

service.interceptors.request.use(
  config => {
    // 在请求发送前做一些处理
    config.headers['Authorization'] = getToken();
    return config;
  },
  error => {
    // 处理请求错误
    return Promise.reject(error);
  }
);

service.interceptors.response.use(
  response => {
    // 在响应数据返回前做一些处理
    return response.data;
  },
  error => {
    // 处理响应错误
    return Promise.reject(error);
  }
);

export default service;

在上述代码中,我们通过 axios.create() 方法创建了一个 Axios 实例,并设置了基本的 baseURL 和 timeout。同时,我们也添加了请求和响应拦截器,用于处理请求和响应的错误信息。

通过封装后的 Axios,我们可以在 Vue3 项目中使用以下方法进行 API 请求:

import request from '@/utils/request';

request({
  url: '/user',
  method: 'get',
  params: {
    id: 1
  }
}).then(data => {
  console.log(data);
}).catch(error => {
  console.log(error);
});

8.2 实践案例

在 Vue3 项目中,我们可以通过封装后的 Axios 进行 API 请求,同时也可以将 Axios 的实例作为 Vue3 的插件进行注册,方便在 Vue3 组件中使用。

以下是一个简单的 Axios 插件示例:

import axios from 'axios';

const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000
});

service.interceptors.request.use(
  config => {
    // 在请求发送前做一些处理
    config.headers['Authorization'] = getToken();
    return config;
  },
  error => {
    // 处理请求错误
    return Promise.reject(error);
  }
);

service.interceptors.response.use(
  response => {
    // 在响应数据返回前做一些处理
    return response.data;
  },
  error => {
    // 处理响应错误
    return Promise.reject(error);
  }
);

const plugin = {
  install: (app, options) => {
    app.config.globalProperties.$axios = service;
  }
};

export default plugin;

在上述代码中,我们通过 app.config.globalProperties.$axios 将 Axios 实例注入到了 Vue3 中,并将其作为全局属性进行使用。

在 Vue3 项目中,我们可以通过以下方法进行插件注册:

import axios from '@/plugins/axios';

createApp(App).use(axios).mount('#app');

在 Vue3 组件中,我们可以通过以下方法进行 API 请求:

export default {
  mounted() {
    this.$axios({
      url: '/user',
      method: 'get',
      params: {
        id: 1
      }
    }).then(data => {
      console.log(data);
    }).catch(error => {
      console.log(error);
    });
  }
}

通过以上方法,我们可以在 Vue3 项目中方便地进行 API 请求,并且也方便后期维护和更新。在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/484755.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NECCS|全国大学生英语竞赛C类|词汇和语法|语法题|时态|22:30~11:44

15题 10min 10:20&#xff5e;10:25 test2 10:25&#xff5e;10:47 test1订正 10:44&#xff5e;11:47 理论学习 涉及的语法点主要包括&#xff1a; 动词的时态和语态 非谓语动词 虚拟语气 主谓一致 倒装句 强调句 比较级 名词性从句 定语…

【SQL篇】面试篇之子查询

1303 求团队人数 # 写法1 # Write your MySQL query statement below select employee_id, count(*) over(partition by team_id) as team_size from Employee# 写法2 # Write your MySQL query statement below select employee_id, team_size from Employee e join (select t…

优雅编程,从空格、空行、缩进、注释开始

很多初学者的代码其实都不够“漂亮”&#xff0c;那是因为没有养成好的编码习惯。本篇博客以C语言为例&#xff0c;总结一些好习惯。其实&#xff0c;很多习惯都是肌肉记忆&#xff0c;举个例子&#xff1a;请你写一个程序&#xff0c;输入2个整数并输出它们的和。有些朋友可能…

springboot+vue前后端分离项目打包成jar包及运行

将 Spring Boot 和 Vue.js 项目打包成 jar 包需要按照以下步骤操作&#xff1a; 在项目的根目录中&#xff0c;使用命令行进入 Vue.js 项目的根目录&#xff0c;然后运行以下命令&#xff1a; npm run build这个命令将会构建 Vue.js 项目&#xff0c;并在项目的 dist 目录中生…

Rust-Rocket框架笔记

Rust-Rocket框架笔记 Rocket-Learn-docRocket Addr视频地址 What is RocketQuickStart下载Rocket-Rust运行Rust-Rocket-Hello-错误-端口占用解决查看端口占用情况添加Rocket.toml配置文件更改Rocket默认启动端口启动成功 GetStart-Hello world创建项目cargoIDEA 添加依赖添加Ro…

使用eclipse创建一个图书管理系统(2)---------逻辑的实现

就像使用C语言写代码一样。比如要用​​​​​​C语言写一个小游戏的代码&#xff0c;我们的逻辑实现是在哪里实现的啊&#xff1f;是不是在一个test.c源文件里面啊&#xff1f;没错&#xff0c;就是的&#xff01;在之前的文章里&#xff0c;我说过我定义的Main函数就像C语言里…

【《中国工业经济》数据复现】数字化转型与企业分工:专业化还是纵向一体化

一.研究内容 本文使用机器学习方法刻画微观企业数字化水平&#xff0c;并在构建数理模型的基础上实证考察了企业数字化转型对企业分工的影响及其机理。结果表明&#xff0c;企业数字化转型显著提升了中国上市企业专业化分工水平。机制分析表明&#xff0c;数字化转型对企业专业…

实现chatgpt自然对话

1.概述 ChatGPT是当前自然语言处理领域的重要进展之一&#xff0c;通过预训练和微调的方式&#xff0c;ChatGPT可以生成高质量的文本&#xff0c;可应用于多种场景&#xff0c;如智能客服、聊天机器人、语音助手等。本文将详细介绍ChatGPT的原理、实战演练和流程图&#xff0c…

C/C++每日一练(20230503)

目录 1. 输出最长的递增数字字符串 &#x1f31f;&#x1f31f; 2. 缺失的第一个正数 &#x1f31f;&#x1f31f;&#x1f31f; 3. 最大矩形 &#x1f31f;&#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日…

SaaS模医学检验信息管理系统源码,系统预设几十种报告模板,可在几分钟内批量生成报告

实验室信息管理系统云LIS源码 SaaS模式运维管理系统 云LIS系统源码是一款全面的实验室信息管理系统源码&#xff0c;其主要功能包括样本管理、检测项目管理、质控管理、报告管理、数据分析、两癌筛查等多个方面。具有独立的配套SaaS模式运维管理系统&#xff0c;支持远程运维&…

Redis高频面试题,使用场景

一、缓存 1、什么是缓存穿透 ? 怎么解决 ? 缓存穿透 查询一个不存在的数据&#xff0c;mysql查询不到数据也不会直接写入缓存&#xff0c;就会导致每次请求都查数据库。 解决 方案一&#xff1a;缓存空数据&#xff0c;查询返回的数据为空&#xff0c;仍把这个空结果进行…

《花雕学AI》28:革命性的 ChatGPT for SEO——让您的排名飙升 50%!

引言&#xff1a; 如果您想写篇有吸引力的文章&#xff0c;或者您是一个博客和网站的拥有者&#xff0c;那么您一定知道 SEO&#xff08;搜索引擎优化&#xff09;的重要性。SEO 可以帮助您提高相应的流量、转化率和收入&#xff0c;但是 SEO 也是一个复杂和耗时的过程&#x…

【开源项目】Dynamic-Tp核心流程源码解读

序.介绍 dynamic-tp 是一款动态线程池组件&#xff0c;可以实现线程池的实时动态调参及监控报警&#xff0c;线程池配置放在配置中心统一管理&#xff0c;达成业务代码零侵入&#xff0c;支持多配置中心的选择和常见的第三方组件的线程池的集成管理。 官网: https://dynamict…

C++学习day--01 C生万物

1、C/C学习中遇到的问题&#xff1a; 1. 大部分初学者&#xff0c;学习 C/C 都是从入门到放弃。 C/C太难吗&#xff1f; 2. 90% 以上的初学者&#xff0c;学完 C/C 以后&#xff0c;考试完了&#xff0c;书看完了&#xff0c; 但还是不会做项目 是学的不够好吗&#xff1…

基于KZG多项式承诺方案的RLN

1. 引言 RLN——Rate-Limiting Nullifier为PSE团队主导的项目&#xff0c;源自&#xff1a; Barry White Hat 2019年博客 Semaphore RLN, rate limiting nullifier for spam prevention in anonymous p2p setting RLN&#xff08;Rate-Limiting Nullifier&#xff09;是一种…

Servlet原理

什么是Servlet? Servlet是JavaWeb应用程序中的一种Java类&#xff0c;用于接收和处理来自客户端的请求&#xff0c;并将生成的响应发送回客户端。 Servlet是按照Java Servlet规范开发的&#xff0c;可以通过Servlet容器&#xff08;如Tomcat&#xff09;来管理和运行。Servl…

二十二、SQL 数据分析实战(案例1~案例10)

文章目录 案例1&#xff1a;用户信息表 stu_table案例2&#xff1a;员工绩效表 score_table案例3&#xff1a;销售冠军信息表 month_table案例4&#xff1a;月销售额记录表 sale_table案例5&#xff1a;每季度员工绩效得分表 score_info_table案例6&#xff1a;员工信息表 stu_…

【大数据】Hadoop总结

本文对于Hadoop中的HDFS和MapReduce的相关面试重点进行了总结&#xff0c;下篇将介绍调优、数据倾斜等进阶知识。 Hadoop总结 一、概述1. Hadoop特性2. HDFS结构HDFS 架构 二、HDFS分布式文件系统1 概述2. HDFS存储数据架构图NameNodeDataNode 3 HDFS优点4 HDFS缺点&#xff08…

利用 Delte-Sigma ADC简化电路设计

很多时候在电路中选择合适的 ADC可以很大程度上简化前端的电路。这里我们一起来看一个电阻电桥的例子&#xff1a; 这里用到了一只仪表放大器和一只运算放大器&#xff0c;他们实际上主要完成了三个功能&#xff1a; 1. 抑制了 2.5V的共模信号&#xff1b; 2. 将-1…

「业务架构」波特的五力分析教程介绍

波特五力分析模型最早出现在哈佛商学院教授迈克尔E波特1979年发表在《哈佛商业评论》上的文章中。这篇论文的发表在历史上改变了企业、组织甚至国家对战略的理解。自《哈佛商业评论》创刊以来&#xff0c;它被评为十大最具影响力的论文之一。 五力分析可以帮助公司评估行业吸引…