【Tip】父子组件传值和页面跳转传值方法(vue和uniapp)

本文介绍了在Vue和uniapp中子组件和父组件之间的传值方法、页面跳转传值方法。

一、父子组件传值

以列表为例:

1、子组件

sonTemplate.vue

(1)挂载显示内容

<el-table>

//列表内容

<el-table>

(2)关键方法

Creat()方法: 子组件列表getList()

Props:绑定要传递的值(父组件传给子组件==用于显示或在子组件上一次操作值基础上操作)

Props:{

sonValue: {
type: Number|String,
},

}

Submit():$emit("方法名method1", values) 传递在子组件操作的值 (子组件传给父组件==值传递)

2、父组件

(1) 挂载内容

javascript 复制代码
<son-template :sonValue="selectValue" @method1="getSelectValue">

(2)关键方法

javascript 复制代码
Import sonTemplate.vue

Compoent:{SonTemplate}

Data(){

selectValue: null,

}

Methods:{

getSelectValue(val){

this.selectValue = val

// 可对val做其他处理filter、map等}

}

二、路由自定义页面跳转和传值(在Vue中)

1、页面跳转

javascript 复制代码
this.$store.dispatch('tagsView/delView', this.$route)

this.$router.push({
  path: '/factory/factoryCheckPlanManager/add',   //'/factory/factoryCheckPlanManager/add为跳转文件的vue目录
  query: {checkPlanId: id, queryParams: this.queryParams}
})

2、接收

javascript 复制代码
create(){

let queryParams = this.$route.query.queryParams

}

三、路由自定义页面跳转和传值(在uniapp中)

1、页面跳转之===父子组件传值(子组件传递给父组件)

页面之间子页面(下一页面)可用$emit返回给父级页面(上一页面),父级页面在onShow方法中监听事件,实现页面之间的组件传值。

常用于较大数据的传送,不宜放在请求地址里

(1) 子页面传值

javascript 复制代码
uni.$emit('updateCheckItem', {
  type:'updateCheckItem',
  checkItem: this.checkItem,
  locationId:Number(this.checkItem.checkUnitLocation)
});

//返回上级页面

uni.navigateBack({
  delta: 1
})

(2) 父页面(上一页面)接收

javascript 复制代码
onShow(){

uni.$off('updateCheckItem');
uni.$once('updateCheckItem', data => {
  if(data.type === "updateCheckItem") {
    that.checkList.forEach((check,key)=>{
      if(check.pointUnitId===data.locationId){
        check.checkItemList.forEach((item,index)=>{
          if(item.id===data.checkItem.id){
            that.checkList[key].checkItemList[index]=data.checkItem;
          }
        })
      }
    })
    uni.hideLoading();
  } else {
    console.log('失败')
  }
})

}

2、页面跳转之===地址跳转

父页面跳转到子页面,要传递的参数值附带在请求地址上,子页面在onLoad函数中接收

(1) 父页面跳转传值

javascript 复制代码
let url="sonVue?describe="+this.checkItem.abnormalDescribe+'&locationId='+this.checkItem.checkUnitLocation;
this.$tab.navigateTo(url);

(2) 子页面接收

sonVue.vue

javascript 复制代码
onLoad(option){
  if(option.describe!=null && option.describe!='null'){
    this.describe=option.describe;
  }
相关推荐
「、皓子~6 分钟前
后台管理系统的诞生 - 利用AI 1天完成整个后台管理系统的微服务后端+前端
前端·人工智能·微服务·小程序·go·ai编程·ai写作
就改了9 分钟前
Ajax——在OA系统提升性能的局部刷新
前端·javascript·ajax
凌冰_11 分钟前
Ajax 入门
前端·javascript·ajax
京东零售技术26 分钟前
京东小程序JS API仓颉改造实践
前端
奋飛35 分钟前
TypeScript系列:第六篇 - 编写高质量的TS类型
javascript·typescript·ts·declare·.d.ts
老A技术联盟35 分钟前
从小白入门,基于Cursor开发一个前端小程序之Cursor 编程实践与案例分析
前端·小程序
风铃喵游39 分钟前
构建引擎: 打造小程序编译器
前端·小程序·架构
sunbyte44 分钟前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | ThemeClock(主题时钟)
前端·javascript·css·vue.js·前端框架·tailwindcss
小飞悟1 小时前
🎯 什么是模块化?CommonJS 和 ES6 Modules 到底有什么区别?小白也能看懂
前端·javascript·设计
浏览器API调用工程师_Taylor1 小时前
AOP魔法:一招实现登录弹窗的全局拦截与动态处理
前端·javascript·vue.js