简单demo

父组件:index.vue

<template>
<div class="app-container">
<vue-props-demo :user-name="name" :age="age" :sex="sex"></vue-props-demo>
</div>
</template>
<script>
import vuePropsDemo from '@/views/skill/propsDemo'
export default {
name:'skill',
data() {
return {
name:'姓名:东东',
age:'年龄:10',
sex:'性别:男',
} },
components:{
'vue-props-demo': vuePropsDemo,
}
}
</script>

子组件propsDemo.vue
<template>
<div class="app-container">
<p v-text="userName"></p>
<p v-text="name"></p>
<p v-text="sex"></p>
<p v-text="age"></p>
</div>
</template>
<script>
export default {
name:'vuePropsDemo',
props:['userName','sex','age'],//props定义
created(){
},
methods: {
getProps(){
}
}
}
</script>

效果:

1.props是什么:(简单的说用于父子组件通信,父传递给子数据)

  ①组件实例的作用域是孤立的,可以使用props在父子组件之间传递数据,在子组件中定义props,在父中通过props向子传递数据

  ②props是单向绑定的,意思是说父组件数据发生变化时,子组件也会发生变化,

  当在子组件中更改数据时,父组件不会发生变化,并且在控制台会发现警告信息,原因是:JS中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态

father.vue

created(){
this.getProps();
},
methods:{
getProps(){
console.log('父组件:',this.name);
}
}

子组件propsDemo.vue
created(){
this.getProps();
},
methods: {
getProps(){
this.userName = '姓名:西西';
console.log('子组件:',this.userName);//子组件中可以这样获取父组件传递的数据
// this.userName = '姓名:西西';在子组件中修改父组件传递的值,会提示一个警告信息
}
}

效果:

2.props定义:

子组件:props:['userName','sex','age'],//多个单词构成时建议使用驼峰命名

父组件::user-name="name"   等价于   v-bind:user-name="name"

3.props分类:静态和动态

静态:user-name="姓名:东东";

动态::user-name="name"

4.props验证

index.vue

<template>
<div class="app-container">
<!-- <vue-props-demo :user-name="name" v-bind:age="age+1" :sex="sex"></vue-props-demo> -->
<vue-props-demo
:msg-null="1+1"
:msg-string="msgString"
:msg-obj="msgObj"
:msg-validate="msgValidate"
:msg-prop= "msgProp"
>
</vue-props-demo> </div>
</template>
<script>
import vuePropsDemo from '@/views/skill/propsDemo'
export default {
name:'skill',
data() {
return {
name:'姓名:东东',
age:10,
sex:'性别:男',
msgString:'String类型,必须是定义过的,可以是空字符串"",</br>如果非String类型,控制台会警告,例定义:msgString:10',
msgObj:{
name:'小红 ',
age:20
},
msgProp:12,
msgValidate:90,
} },
components:{
'vue-props-demo': vuePropsDemo,
},
created(){
this.getProps();
},
methods:{
getProps(){
console.log('父组件:',this.name);
}
}
}
</script>

propsDemo.vue

<template>
<div class="app-container">
<!-- <p v-text="userName"></p>
<p v-text="sex"></p>
<p v-text="age"></p> -->
<div class="title">props验证</div>
<el-form class="wrap-form" label-width="180px">
<el-form-item label="null类型props:">
<span v-text="msgNull"></span>
</el-form-item>
<el-form-item label="string类型props:">
<span v-html="msgString"></span>
</el-form-item>
<el-form-item label="number类型props:">
<span v-text="msgNumber"></span>
</el-form-item>
<el-form-item label="obj类型props:">
<span v-text="msgObj.name"></span>
<span v-text="msgObj.age"></span>
</el-form-item>
<el-form-item label="自定义验证props:">
<span v-text="msgValidate"></span>
</el-form-item>
<el-form-item label="多种类型props:">
<span v-text="msgProp"></span>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
name:'vuePropsDemo',
//props:['userName','sex','age'],//props定义
props:{
msgNull:null,//基础类型检测('null')意思是任何类型都可以
msgProp: [String, Number], // 多种类型
msgString:{//String类型,必须是定义过的,可以是空字符串""
type:String,
required:true,
},
msgNumber:{//Number类型,默认值100
type:Number,
default:100
},
msgObj:{//Object对象,返回值必须是js对象
type:Object,
default:function(){
return {
name:'lisa',
age:18
} }
},
msgValidate:{//自定义验证,必须是Number类型,验证规则:大于10,如果不满足条件,控制台会抛出警告
type:Number,
validator: function(val){
return val > 10;
}
}, },
data() {
return {
}
},
created(){},
methods: {}
}
</script>
<style>
.title{
font-size: 14px;
padding-left: 20px;
color: #333;
line-height: 34px;
background-color: #F5F5F5;
}
</style>

效果:

5.修改props数据

2种情况:
1、prop 作为初始值传入后,子组件想把它当作局部数据来用 2、prop 作为初始值传入,由子组件处理成其它数据输出

index.vue

<vue-props-demo :child-msg="msg"></vue-props-demo>
父组件 <input v-model="msg">{{msg}}

propsDemo.vue

<el-form-item label="子组件props:">
<input v-model="temp">
{{temp}}
</el-form-item>
props:['childMsg'],
data() {
return {
temp:this.childMsg
}
},
created(){},
methods: {},
watch:{
childMsg(){
this.temp = this.childMsg
}
}

参考资料:https://www.cnblogs.com/xiaohuochai/p/7388866.html

     https://vuejs.org/v2/guide/components-props.html#ad

     https://www.cnblogs.com/zhuruiyu/p/6917852.html

     

【vue】vue +element prop用法的更多相关文章

  1. 使用vue与element组件

    1.安装element npm i element-ui -S 2.引入 在main.js写入一下内容 import Vue from 'vue'; import ElementUI from 'el ...

  2. Vue + TypeScript + Element 搭建简洁时尚的博客网站及踩坑记

    前言 本文讲解如何在 Vue 项目中使用 TypeScript 来搭建并开发项目,并在此过程中踩过的坑 . TypeScript 具有类型系统,且是 JavaScript 的超集,TypeScript ...

  3. 【vue】vue使用Element组件时v-for循环里的表单项验证方法

    转载至:https://www.jb51.net/article/142750.htm标题描述看起来有些复杂,有vue,Element,又有表单验证,还有v-for循环?是不是有点乱?不过我相信开发中 ...

  4. 关于vue.js element ui 表单验证 this.$refs[formName].validate()的问题

        方法使用前需了解: 来自”和“小编的小提示: 首先打印一下this.$refs[formName],检查是否拿到了正确的需要验证的form. 其次在拿到了正确的form后,检查该form上添加 ...

  5. Vue. 之 Element table 单元格内容隐藏

    Vue. 之 Element table 单元格内容隐藏 在table显示数据时,若某个单元格的内容过多,需要进行隐层,在这一列的单元格属性添加::show-overflow-tooltip=&quo ...

  6. vue中的一些用法,持续更新中......

    1.跳转用法 @1.在template模板中通常使用router-link to='url' @2.在js中 1.this.$router.push({path: ''/order/index''}) ...

  7. vue.runtime.esm.js:593 [Vue warn]: Invalid prop: custom validator check failed for prop "value".报错解决

    在uni中使用 picker组件,一直报错 vue.runtime.esm.js:593 [Vue warn]: Invalid prop: custom validator check failed ...

  8. vue使用element Transfer 穿梭框实现ajax请求数据和自定义查询

    vue使用element Transfer 穿梭框实现ajax请求数据和自定义查询 基于element Transfer http://element-cn.eleme.io/#/zh-CN/comp ...

  9. Vue中directives的用法

    关于 vue 中 directives 的用法问题,详细可以参考vue官方对directives的解释 当前文章主要讲述directives怎么用,directives做权限按钮的功能 ###1. d ...

随机推荐

  1. springboot整合netty(二)

    目录 前言 正文 代码 1. 新建一个springboot项目,在pom文件中添加netty依赖: 2.新建netty服务 3.netty调用所需的服务类 4 springboot启动类 5.测试 我 ...

  2. css3巧用选择器配合伪元素

    一 . 前言 有时我们在写底部导航栏时,会有很多超链接,每个链接间用“|”分割,如下图: 可能刚入门的朋友会想到这样完成,再单独设置span的样式, 今天主要介绍怎么样用css3简单快速的完成这个效果 ...

  3. Github被微软收购,这里整理了16个替代品

    微软斥资75亿美元收购以后,鉴于微软和开源竞争的历史,很多开发者都感到惊恐.毕竟,互联网上最大的一块可以自由的净土被微软染指,宝宝不开森.如果你真的担心微软会对Github有所动作,那么这里我列举了1 ...

  4. favicon.ico在chrome里显示正常,在ie,edge浏览器中不显示

    代码: <head> <meta charset="UTF-8"> <link href="imgs/favicon.ico" r ...

  5. IE CSS Hack【记录】

    1.条件hack 2.属性hack 3.选择器hack CSS Hack一般都是利用各浏览器的支持CSS的能力和BUG来进行的 本文只列举了一些常用的CSS Hack,且不考虑IE6以下的版本 尽可能 ...

  6. CSS琐碎知识点(持续补充)

    一.字体单位,pt?px?em?rem? pt:磅,一种固定长度的绝对的度量单位,是能够使用测量设备测得的长度,印刷业上经常使用,一般用于页面打印排版. px:屏幕设备上能显示出的最小的一个物理点,这 ...

  7. centos6 自带python2.6升级python2.7+

    centos6系统自带Python为2.6.6版本,升级搞版本操作如下(python2-python3都一样) 1.下载需要升级的python包 官方下载地址:https://www.python.o ...

  8. loadrunner 脚本优化-检查点设置

    脚本优化-检查点设置 by:授客 QQ:1033553122 VuGen判断脚本是否执行成功是根据服务器返回的状态来确定的,如果服务器返回的是HTTP状态为200 OK,那么VuGen就认为脚本正确地 ...

  9. Android为TV端助力 post带数据请求方式,传递的数据格式包括json和map

    如下: public static String httpPost(String url, String json) { try { URL u = new URL(url); HttpURLConn ...

  10. Android Studio NDK JNI动态注册本地方法

    概述 可能大家觉得javah生成的函数名又臭又长,不太好看.这里可以提供另外一种方法来动态注册c++函数,让其根Java中的native方法关联起来. 实现 这里通过JNIEnv的Resisterna ...