欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue使用axios發(fā)送請(qǐng)求簡(jiǎn)單實(shí)現(xiàn)代碼

 更新時(shí)間:2023年04月04日 08:44:35   作者:ForestSpringH  
axios是一個(gè)基于Promise的,發(fā)送http請(qǐng)求的一個(gè)工具庫(kù),并不是vue中的第三方插件,使用時(shí)不能通過(guò)“Vue.use()”安裝插件,需要在原型上進(jìn)行綁定

上一篇文章我們?cè)趘ue工程項(xiàng)目中引入了axios庫(kù)并將通用的API進(jìn)行了封裝,但是遇到了一個(gè)問(wèn)題就是我們?cè)诮M件內(nèi)部寫(xiě)的函數(shù)發(fā)送請(qǐng)求是不會(huì)被vue實(shí)例進(jìn)行執(zhí)行的,也就是說(shuō)VC中的函數(shù)無(wú)法直接的由VM去接管執(zhí)行,這時(shí)我們需要將這個(gè)請(qǐng)求的執(zhí)行函數(shù)位置調(diào)到APP這個(gè)父組件上去,因?yàn)橹挥蠥PP組件被所謂的VM給接管了的,其他的組件都是APP組件的子組件。

例:當(dāng)我們?cè)贏PP組件的子組件UserLogin組件中寫(xiě)到登錄函數(shù):

    login(){
      console.log('登錄')
      let params = {
        userAccount: UserInfo.userAccount,
        password: UserInfo.password
      }
      // 防止閉包找不到data元素的調(diào)用
      let that = this 
      API.login(params).then(
        function (res) {
          // res.data = res
          if (res.code == 1) {
            that.userAccount = params.userAccount
            that.authority = 1
            that.loginWord = false
            that.SystemFrom(0)
          }
          else
            that.SystemFrom(1)
        }
      },

這時(shí)的登錄函數(shù)是沒(méi)辦法在子組件內(nèi)部進(jìn)行運(yùn)行的。也就是我跑起來(lái)之后是沒(méi)辦法通過(guò)登錄按鈕進(jìn)行訪問(wèn)服務(wù)器接收數(shù)據(jù)的。

這里我將這行代碼放進(jìn)我們的APP組件中就成功的實(shí)現(xiàn)了數(shù)據(jù)的訪問(wèn)與接收。但是這涉及到子組件與父組件的數(shù)據(jù)通信的方式:上次說(shuō)道this.$emit('父組件在子組件上綁定的方法名')可以實(shí)現(xiàn)子組件調(diào)用父組件的方法,而在父組件調(diào)用子組件時(shí)如果有<login name=' params '>就可以在子組件內(nèi)的props:[' name']對(duì)該參數(shù)進(jìn)行接收,之后的處理都是以name進(jìn)行操作的,那么我們其實(shí)也可以將其變成一個(gè)函數(shù)就可以直接在子組件內(nèi)部調(diào)用父組件的函數(shù)了。

父組件相關(guān)代碼:

    <div v-if="loginWord === true">
      <login @close="closeL" :startLogin="startLogin"></login>
    </div>
    //以下是methods內(nèi)部
    // 登錄請(qǐng)求發(fā)起
    startLogin(UserInfo){
      console.log('登錄')
      let params = {
        userAccount: UserInfo.userAccount,
        password: UserInfo.password
      }
      // 防止閉包找不到data元素的調(diào)用
      let that = this 
      API.login(params).then(
        function (res) {
          // res.data = res
          if (res.code == 1) {
            that.userAccount = params.userAccount
            that.authority = 1
            that.loginWord = false
            that.SystemFrom(0)
          }
          else
            that.SystemFrom(1)
        }
      )
    },

子組件代碼:

      UserInfo:{
          userAccount:"",
          password:""
      }, 
    //以上是data內(nèi)部
    // 接收父組件APP傳遞的函數(shù)startLogin
      props:['startLogin'],
    //以下是methods內(nèi)部
      login(){
        // 調(diào)用父組件傳遞的函數(shù)并傳遞UserLogin對(duì)象
        this.startLogin(this.UserInfo)
      },

當(dāng)然父子組件間的通信還可以通過(guò) 消息的訂閱與發(fā)布 ,全局事件總線的方式進(jìn)行設(shè)置,但是我沒(méi)還沒(méi)用到,等用到了再寫(xiě)出來(lái)。

到此這篇關(guān)于Vue使用axios發(fā)送請(qǐng)求簡(jiǎn)單實(shí)現(xiàn)代碼的文章就介紹到這了,更多相關(guān)Vue axios發(fā)送請(qǐng)求內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 整理項(xiàng)目中vue.config.js打包優(yōu)化配置方法

    整理項(xiàng)目中vue.config.js打包優(yōu)化配置方法

    這篇文章主要介紹了整理項(xiàng)目中vue.config.js打包優(yōu)化,包括配置?webpack-bundle-analyzer?插件查看文件大小及配置compression-webpack-plugin?用gzip壓縮打包的文件大小,本文結(jié)合實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • el-date-picker時(shí)間清空值為null處理方案

    el-date-picker時(shí)間清空值為null處理方案

    本文介紹關(guān)于Vue.js項(xiàng)目中時(shí)間選擇器組件的問(wèn)題,當(dāng)選擇后清空導(dǎo)致值變?yōu)閚ull,進(jìn)而引發(fā)后臺(tái)接口報(bào)錯(cuò),通過(guò)監(jiān)聽(tīng)`overallForm.time`的值并設(shè)置為空數(shù)組,成功解決此問(wèn)題,確保了數(shù)據(jù)正確性,同時(shí),建議避免直接監(jiān)聽(tīng)整個(gè)對(duì)象以優(yōu)化性能,感興趣的朋友一起看看吧
    2024-08-08
  • Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例

    Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例

    頁(yè)面中會(huì)有很多時(shí)候需要彈窗提示,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置提示和警告彈出框的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • vue項(xiàng)目本地開(kāi)發(fā)完成后部署到服務(wù)器后報(bào)404錯(cuò)誤解決方案

    vue項(xiàng)目本地開(kāi)發(fā)完成后部署到服務(wù)器后報(bào)404錯(cuò)誤解決方案

    很多時(shí)候我們發(fā)現(xiàn)辛辛苦苦寫(xiě)的VueJs應(yīng)用經(jīng)過(guò)打包后在自己本地搭建的服務(wù)器上測(cè)試沒(méi)有什么問(wèn)題,但真正放在服務(wù)器上后會(huì)發(fā)現(xiàn)或多或少的問(wèn)題,這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目本地開(kāi)發(fā)完成后部署到服務(wù)器后報(bào)404錯(cuò)誤的解決方案,需要的朋友可以參考下
    2024-01-01
  • vue3使用ref 獲取不到子組件屬性問(wèn)題的解決辦法

    vue3使用ref 獲取不到子組件屬性問(wèn)題的解決辦法

    父子組件使用<script setup>語(yǔ)法糖,父組件通過(guò)給子組件定義ref訪問(wèn)子組件內(nèi)部屬性或事件,本文給大家介紹了解決vue3使用ref 獲取不到子組件屬性問(wèn)題,文中通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下
    2024-06-06
  • vant-ui組件庫(kù)中如何修改NavBar導(dǎo)航欄的樣式

    vant-ui組件庫(kù)中如何修改NavBar導(dǎo)航欄的樣式

    這篇文章主要介紹了vant-ui組件庫(kù)中如何修改NavBar導(dǎo)航欄的樣式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue 如何向集合的頭部添加元素

    Vue 如何向集合的頭部添加元素

    在 Vue 中,如果要向集合的頭部添加元素,可以使用 JavaScript 的 unshift 方法或 Vue 的 $set 方法,本文給大家介紹Vue 向集合的頭部添加元素的方法,感興趣的朋友一起看看吧
    2023-12-12
  • 深入淺析Vue.js 中的 v-for 列表渲染指令

    深入淺析Vue.js 中的 v-for 列表渲染指令

    當(dāng)遍歷一個(gè)數(shù)組或枚舉一個(gè)對(duì)象進(jìn)行迭代循環(huán)展示時(shí),就會(huì)用到列表渲染指令 v-for。這篇文章主要介紹了Vue.js 中的 v-for 列表渲染指令,需要的朋友可以參考下
    2018-11-11
  • vue實(shí)現(xiàn)禁止瀏覽器記住密碼功能的示例代碼

    vue實(shí)現(xiàn)禁止瀏覽器記住密碼功能的示例代碼

    這篇文章主要介紹了vue實(shí)現(xiàn)禁止瀏覽器記住密碼功能的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • npm?install安裝報(bào)錯(cuò)的幾種常見(jiàn)情況

    npm?install安裝報(bào)錯(cuò)的幾種常見(jiàn)情況

    當(dāng)你跑起一個(gè)項(xiàng)目的時(shí)候,第一步需要先安裝依賴npm install,下面這篇文章主要給大家介紹了關(guān)于npm?install安裝報(bào)錯(cuò)的幾種常見(jiàn)情況,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07

最新評(píng)論