Vue使用axios發(fā)送請求簡單實現(xiàn)代碼
上一篇文章我們在vue工程項目中引入了axios庫并將通用的API進行了封裝,但是遇到了一個問題就是我們在組件內(nèi)部寫的函數(shù)發(fā)送請求是不會被vue實例進行執(zhí)行的,也就是說VC中的函數(shù)無法直接的由VM去接管執(zhí)行,這時我們需要將這個請求的執(zhí)行函數(shù)位置調(diào)到APP這個父組件上去,因為只有APP組件被所謂的VM給接管了的,其他的組件都是APP組件的子組件。
例:當我們在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)部進行運行的。也就是我跑起來之后是沒辦法通過登錄按鈕進行訪問服務(wù)器接收數(shù)據(jù)的。
這里我將這行代碼放進我們的APP組件中就成功的實現(xiàn)了數(shù)據(jù)的訪問與接收。但是這涉及到子組件與父組件的數(shù)據(jù)通信的方式:上次說道this.$emit('父組件在子組件上綁定的方法名')可以實現(xiàn)子組件調(diào)用父組件的方法,而在父組件調(diào)用子組件時如果有<login name=' params '>就可以在子組件內(nèi)的props:[' name']對該參數(shù)進行接收,之后的處理都是以name進行操作的,那么我們其實也可以將其變成一個函數(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)
},當然父子組件間的通信還可以通過 消息的訂閱與發(fā)布 ,全局事件總線的方式進行設(shè)置,但是我沒還沒用到,等用到了再寫出來。
到此這篇關(guān)于Vue使用axios發(fā)送請求簡單實現(xiàn)代碼的文章就介紹到這了,更多相關(guān)Vue axios發(fā)送請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue框架中如何調(diào)用模擬數(shù)據(jù)你知道嗎
這篇文章主要為大家詳細介紹了Vue框架中如何調(diào)用模擬數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
Vue3 根據(jù)路由動態(tài)生成側(cè)邊菜單的方法
本文介紹了如何在Vue3項目中根據(jù)路由動態(tài)生成側(cè)邊菜單,包括準備工作、路由配置基礎(chǔ)、組件搭建和優(yōu)化與拓展,通過這些步驟,可以實現(xiàn)一個靈活且可擴展的側(cè)邊菜單系統(tǒng),提升用戶體驗,感興趣的朋友一起看看吧2025-01-01
vue使用css-rcurlyexpected等less報錯問題
這篇文章主要介紹了vue使用css-rcurlyexpected等less報錯問題,具有很的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vue和webpack項目構(gòu)建過程常用的npm命令詳解
本文通過實例代碼給大家介紹了vue和webpack項目構(gòu)建過程常用的npm命令,需要的朋友可以參考下2018-06-06

