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

關(guān)于Vue的URL轉(zhuǎn)跳與參數(shù)傳遞方式

 更新時(shí)間:2023年03月10日 11:18:08   作者:楊哥學(xué)編程  
這篇文章主要介紹了關(guān)于Vue的URL轉(zhuǎn)跳與參數(shù)傳遞方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Vue URL轉(zhuǎn)跳與參數(shù)傳遞

寫業(yè)務(wù)中,從一個(gè)頁面跳轉(zhuǎn)到另一個(gè)頁面,經(jīng)常需要傳值和取值,如何實(shí)現(xiàn)?

1.通過router-link進(jìn)行跳轉(zhuǎn)

使用query傳遞參數(shù),路由必須使用path引入

<-- 在a頁面進(jìn)行傳值 -->
? ??
<router-link :to="{path: '/home', query: {key: 'hello', value: 'world'}}">
  <button>跳轉(zhuǎn)</button>
</router-link> 

跳轉(zhuǎn)地址 => /home?key=hello&value=world

在b頁面取值: this.$route.query.key

使用params傳遞參數(shù),路由必須使用name引入

<-- 在a頁面進(jìn)行傳值 -->
? ??
<router-link :to="{name: '/home', params: {key: 'hello', value: 'world'}}">
  <button>跳轉(zhuǎn)</button>
</router-link>  

跳轉(zhuǎn)地址 ==> /home

在b頁面取值:this.$route.params.key

2.$router方式跳轉(zhuǎn)

通過query

this.$router.push({
  path: '/detail',
  query: {
    name: 'admin',
    code: 10021
  }
});

跳轉(zhuǎn)地址 => /detail?name=admin&code=10021

取值:this.$route.query.name

3.跳轉(zhuǎn)外部鏈接

如果是vue頁面中的內(nèi)部跳轉(zhuǎn),可以用this.$router.push()實(shí)現(xiàn),但是如果用這種方法跳到外部鏈接,就會(huì)報(bào)錯(cuò),原因是直接把外部鏈接加在了http://localhost:8080/#/的后面,這就導(dǎo)致跳轉(zhuǎn)出現(xiàn)問題。

那么如何跳轉(zhuǎn)到外部鏈接呢,其實(shí)只需用 window.location.href = ‘url’就能實(shí)現(xiàn)。

具體代碼如下:html <span @click="See(url)">點(diǎn)擊轉(zhuǎn)跳</span>

上面是觸發(fā)一個(gè)點(diǎn)擊事件,其中url是傳給see的url鏈接,下面是事件執(zhí)行的函數(shù)

js See(e) { window.location.href = e }

Vue參數(shù)傳遞的幾種方法

開發(fā)過程中參數(shù)傳遞

1.通過name傳遞參數(shù)

這里寫圖片描述

圖一

這里寫圖片描述

圖二

我們常把頁面的路由配置在圖一中的 router 文件夾下的 js 文件中,圖二為配置的內(nèi)容。這其中的 name 屬性是可以作為參數(shù)傳遞的,在模版中直接只用 {{$route.name}} 接收,即可以在模版中顯示。

2.通過<router-link>中的to傳遞參數(shù)

使用 < router-link to=" /page "> page < /router-link > 可以實(shí)現(xiàn)頁面的跳轉(zhuǎn),這里面 to 是可以帶上參數(shù)跳轉(zhuǎn)的,我們需要在給 to 進(jìn)行綁定,即 : to (v-bind:to)

<router-link :to="{name:'page',params:{data:'我是App.vue傳至page.vue的參數(shù)'}}" >page</router-link>
  • 這其中需要注意的是要給 to 加上綁定,后面跟的是對(duì)象形式的字符串。
  • 其中的 name 是我們在路由配置文件(上圖圖二)中配置的 name 兩者要對(duì)應(yīng)。
  • params 即是我們要傳的參數(shù),它可以是多個(gè)值。

隨后在對(duì)應(yīng)的模版頁面中(這里為 page.vue)進(jìn)行接收。

{{$route.params.data}}

3.在業(yè)務(wù)邏輯中實(shí)現(xiàn)頁面跳轉(zhuǎn)并傳參

當(dāng)在業(yè)務(wù)邏輯中需要實(shí)現(xiàn)頁面跳轉(zhuǎn)經(jīng)常能夠使用到編程式導(dǎo)航:

  • this.$router.go(1),進(jìn)入下一級(jí)
  • this.$router.back(-1),返回上一級(jí),通俗的說就是前進(jìn)與后退。
  • this.$router.push(’/page’),跳轉(zhuǎn)到 page.vue

那么我們應(yīng)該如何傳遞參數(shù)呢?例如,我們在判斷完某個(gè)條件后需要跳轉(zhuǎn)到 page 頁并且需要傳遞 age 和 address 兩個(gè)參數(shù)過去,我們的操作方法是:

App.vue

<div @click="toPage">page</div>

我們在需要的地方加上點(diǎn)擊事件

toPage(){
      this.$router.push({
        name: 'page',
        params: {
          age: 22,
          address: 'China'
        }
      })
    }

隨后在 methods 中寫入該事件,需要注意的是這里面的 name 同樣是要與在配置路由時(shí)配置的 name 屬性保持一致。

params 是我們傳入的參數(shù),可以是常量也可以是變量。

page.vue

在 page.vue 中接收參數(shù),可以在生命周期的 mounted() 接收并且放入 data ,再在模版上顯示出來。

<template>
	<div>
		{{myage}}-{{myaddress}}
	</div>
</template>

<script>
	export default {
		name: "page111",
		data() {
			return {
				myage: '',
				myaddress: ''
			}
		},
		mounted(){
			// 在掛載時(shí)接收到參數(shù)并且賦值
			this.myage = this.$route.params.age;
			this.myaddress = this.$route.params.address;
		},
	}
</script>

4.利用url傳參

在項(xiàng)目開發(fā)過程中常常通過 url 進(jìn)行參數(shù)傳遞,在 vue-cli 中該如何操作呢?

1.在配置路由處以冒號(hào)形式,在 url 后方加上參數(shù)(/src/router/index.js)

{
	path: '/page/:pageId/:pageTitle',
    name: 'page',
    component: page
}

2.在< router-link >< /router-link > 的 to 屬性中加入?yún)?shù)(App.vue)

<template>
  <div id="app">
    <img src="./assets/logo.png"><br/>
      <router-link to="/" >index</router-link>
      <router-link to="/page/1/標(biāo)題" >page</router-link>
    <router-view/>
  </div>
</template>

3.在 page.vue 中接收參數(shù)

<template>
	<div>
		<p>id: {{$route.params.pageId}}</p>
		<p>標(biāo)題: {{$route.params.pageTitle}}</p>
	</div>
</template>

5.父組件與子組件之間傳參

項(xiàng)目中組件是經(jīng)常被使用到的,那么父組件與子組件之間的聯(lián)動(dòng)是非常重要的。

1.先建立一個(gè)組件并且使用,在 components 文件夾下新建 component.vue 文件作為組件。

<template>
	<div>
		<p>我的組件 {{msg}}-{{content}}</p>
	</div>
</template>

<script>
	export default{
		name: 'child',
		props: ["msg","content"],
	}
</script>

隨后在 page.vue 中引入該組件,在 < script > </ script > 中 import 且引用,隨后在模版中使用,如下:

<template>
	<div>
		<children></children>
	</div>
</template>

<script>
	import children from "./component";
	export default {
		name: "page",
		components: {
			children
		}
	}
</script>

要傳遞參數(shù),可以在 < children > </ children >標(biāo)簽中加入要傳入的參數(shù),并且在組件(component.vue)中使用 props 接收再使用插值在模版中顯示。

同時(shí)我們也可以給要傳的參數(shù)綁定起來,如下第二種寫法,在參數(shù)前加上冒號(hào)(v-bind)這樣我們就能在 data 中編輯我們的參數(shù)了。

// page.vue
<children msg="我是信息" content="我是內(nèi)容"></children>

<children :msg="message" :content="content"></children>
<script>
	import children from "./component";
	export default{
		name: 'page',
		components: {
			children
		},
		data(){
			return {
				message: '我是信息',
				content: '我是內(nèi)容'
			}
		}
	}
</script>

// component.vue
<p>我的組件 {{msg}}-{{content}}</p>

<script>
	export default{
		name: 'child',
		props: ["msg","content"]
	}
</script>

子組件再傳值回父組件,在函數(shù)中使用 this.$emit()

// component.vue
<script>
	export default{
		name: 'component',
		data() {
			return {
				param:"需要傳回的參數(shù)",
				data: "參數(shù)2"
			}
		},
		props: ["msg","content"],
		methods: {
			// 假設(shè)在子組件選擇完畢后點(diǎn)擊將 param 傳回
			chooseOk(){
				// ...中間的邏輯處理省略
				this.$emit('changeData',this.param,this.data);
			}
		}
	}
</script>

在 page.vue 的 < children > 標(biāo)簽中加入 @changeData,即可在點(diǎn)擊子組件之后在父組件出接收到傳過來的參數(shù)

<children :msg="msg" :content="content" @changeData="dataChange"></children>

<script>
	import children from "./component";
	export default {
		name: "page",
		components: {
			children
		},
		methods: {
			dataChange(param,data){
				console.log(param + ',' + data);
			}
		}
	}
</script>

最后在附加一點(diǎn),在父組件中該如何調(diào)用子組件中的函數(shù)呢,這里需要用到 ref 屬性,添加在我們的 < children > 標(biāo)簽中

// page.vue
<div @click="ifClick">click</div>
<children ref="child" :msg="msg" :content="content" @changeData="dataChange"></children>

// 重復(fù)部分省略 ...
methods: {
	ifClick(){
		this.$refs.child.isClick();
	}
}

// component.vue
methods: {
	isClick(){
		console.log("父組件點(diǎn)擊了");
	}
}

好了,以上就是我在學(xué)習(xí)過程中能夠使用到的幾種方式。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3如何清空Reactive定義的數(shù)組

    Vue3如何清空Reactive定義的數(shù)組

    這篇文章主要介紹了Vue3如何清空Reactive定義的數(shù)組問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue使用jsmind實(shí)現(xiàn)生成腦圖的示例代碼

    Vue使用jsmind實(shí)現(xiàn)生成腦圖的示例代碼

    這篇文章主要為大家詳細(xì)介紹了Vue如何使用jsmind實(shí)現(xiàn)生成腦圖,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下
    2024-03-03
  • vue路由傳參方式的方式總結(jié)及獲取參數(shù)詳解

    vue路由傳參方式的方式總結(jié)及獲取參數(shù)詳解

    vue 路由傳參的使用場景一般都是應(yīng)用在父路由跳轉(zhuǎn)到子路由時(shí),攜帶參數(shù)跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于vue路由傳參方式的方式總結(jié)及獲取參數(shù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • 為什么vue中不建議使用空字符串作為className

    為什么vue中不建議使用空字符串作為className

    本文主要介紹了為什么vue中不建議使用空字符串作為className,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • ElementUI?Upload源碼組件上傳流程解析

    ElementUI?Upload源碼組件上傳流程解析

    這篇文章主要為大家介紹了ElementUI?Upload源碼組件上傳流程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 前端Vue項(xiàng)目部署到服務(wù)器的全過程以及踩坑記錄

    前端Vue項(xiàng)目部署到服務(wù)器的全過程以及踩坑記錄

    使用Vue做前后端分離項(xiàng)目時(shí),通常前端是單獨(dú)部署,用戶訪問的也是前端項(xiàng)目地址,因此前端開發(fā)人員很有必要熟悉一下項(xiàng)目部署的流程,下面這篇文章主要給大家介紹了關(guān)于前端Vue項(xiàng)目部署到服務(wù)器的全過程以及踩坑記錄的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 圖解Vue?響應(yīng)式流程及原理

    圖解Vue?響應(yīng)式流程及原理

    這篇文章主要為大家介紹了圖解Vue的響應(yīng)式原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問題

    vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問題

    這篇文章主要介紹了vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue中this.$refs的坑及解決

    vue中this.$refs的坑及解決

    這篇文章主要介紹了vue中this.$refs的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例

    vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例

    本文主要介紹了vue element el-form 多級(jí)嵌套驗(yàn)證的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評(píng)論