Vue使用axios發(fā)送請求簡單實(shí)現(xiàn)代碼
上一篇文章我們在vue工程項(xiàng)目中引入了axios庫并將通用的API進(jìn)行了封裝,但是遇到了一個問題就是我們在組件內(nèi)部寫的函數(shù)發(fā)送請求是不會被vue實(shí)例進(jìn)行執(zhí)行的,也就是說VC中的函數(shù)無法直接的由VM去接管執(zhí)行,這時我們需要將這個請求的執(zhí)行函數(shù)位置調(diào)到APP這個父組件上去,因?yàn)橹挥蠥PP組件被所謂的VM給接管了的,其他的組件都是APP組件的子組件。
例:當(dāng)我們在APP組件的子組件UserLogin組件中寫到登錄函數(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ù)是沒辦法在子組件內(nèi)部進(jìn)行運(yùn)行的。也就是我跑起來之后是沒辦法通過登錄按鈕進(jìn)行訪問服務(wù)器接收數(shù)據(jù)的。
這里我將這行代碼放進(jìn)我們的APP組件中就成功的實(shí)現(xiàn)了數(shù)據(jù)的訪問與接收。但是這涉及到子組件與父組件的數(shù)據(jù)通信的方式:上次說道this.$emit('父組件在子組件上綁定的方法名')可以實(shí)現(xiàn)子組件調(diào)用父組件的方法,而在父組件調(diào)用子組件時如果有<login name=' params '>就可以在子組件內(nèi)的props:[' name']對該參數(shù)進(jìn)行接收,之后的處理都是以name進(jìn)行操作的,那么我們其實(shí)也可以將其變成一個函數(shù)就可以直接在子組件內(nèi)部調(diào)用父組件的函數(shù)了。
父組件相關(guān)代碼:
<div v-if="loginWord === true"> <login @close="closeL" :startLogin="startLogin"></login> </div> //以下是methods內(nèi)部 // 登錄請求發(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對象 this.startLogin(this.UserInfo) },
當(dāng)然父子組件間的通信還可以通過 消息的訂閱與發(fā)布 ,全局事件總線的方式進(jìn)行設(shè)置,但是我沒還沒用到,等用到了再寫出來。
到此這篇關(guān)于Vue使用axios發(fā)送請求簡單實(shí)現(xiàn)代碼的文章就介紹到這了,更多相關(guān)Vue axios發(fā)送請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue axios庫避免重復(fù)發(fā)送請求的示例介紹
- Vue?axios庫發(fā)送請求的示例介紹
- Vue使用axios發(fā)送請求并實(shí)現(xiàn)簡單封裝的示例詳解
- vue項(xiàng)目使用axios發(fā)送請求讓ajax請求頭部攜帶cookie的方法
- vue中axios處理http發(fā)送請求的示例(Post和get)
- Vue.js實(shí)戰(zhàn)之使用Vuex + axios發(fā)送請求詳解
- vue-cli3.0 axios跨域請求代理配置方式及端口修改
- Vue3.0?axios跨域請求代理服務(wù)器配置方式
- Vue利用axios發(fā)送請求并代理請求的實(shí)現(xiàn)代碼
相關(guān)文章
整理項(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-02Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例
頁面中會有很多時候需要彈窗提示,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置提示和警告彈出框的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02vue項(xiàng)目本地開發(fā)完成后部署到服務(wù)器后報404錯誤解決方案
很多時候我們發(fā)現(xiàn)辛辛苦苦寫的VueJs應(yīng)用經(jīng)過打包后在自己本地搭建的服務(wù)器上測試沒有什么問題,但真正放在服務(wù)器上后會發(fā)現(xiàn)或多或少的問題,這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目本地開發(fā)完成后部署到服務(wù)器后報404錯誤的解決方案,需要的朋友可以參考下2024-01-01vant-ui組件庫中如何修改NavBar導(dǎo)航欄的樣式
這篇文章主要介紹了vant-ui組件庫中如何修改NavBar導(dǎo)航欄的樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08vue實(shí)現(xiàn)禁止瀏覽器記住密碼功能的示例代碼
這篇文章主要介紹了vue實(shí)現(xiàn)禁止瀏覽器記住密碼功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02