vue学习十一(全局局部组件、prop传不同值、 v-bind 动态赋值、单向数据流、prop校验)

本文主要是介绍vue学习十一(全局局部组件、prop传不同值、 v-bind 动态赋值、单向数据流、prop校验),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 全局注册
      • 局部注册
      • dom模板解析注意事项
      • 用 Prop 传递不同值类型
      • 用 Prop通过 v-bind 动态赋值
      • 用 Prop传递对象的所有属性
      • 用 Prop传递对象数组
      • 用 Prop传入一个数字
      • 单向数据流
      • Prop 验证

全局注册

我们只用过 Vue.component 来创建组件
这些组件是全局注册的。也就是说它们在注册之后可以用在任何新创建的 Vue 根实例 (new Vue) 的模板中。比如

  <div id="div1"><my-component></my-component></div><script type="text/javascript">Vue.component('my-component', {template: '<div>A custom component!</div>'})new Vue({el: "#div1",data: {}})</script>

局部注册

在这些情况下,你可以通过一个普通的 JavaScript 对象来定义组件:

var ComponentA = { /* ... */ }

然后在 components 选项中定义你想要使用的组件:

new Vue({el: '#app',components: {'component-a': ComponentA,'component-b': ComponentB}
})

对于 components 对象中的每个属性来说,其属性名就是自定义元素的名字,其属性值就是这个组件的选项对象

我们看下面的例子:

<div id="div2"><my-component></my-component></div><script type="text/javascript">var Child = {template: '<div>A custom component!</div>'}new Vue({el: "#div2",components: {'my-component': Child}})</script>

dom模板解析注意事项

有些 HTML 元素,诸如 <ul>、<ol>、<table> 和 <select>,对于哪些元素可以出现在其内部是有严格限制的。而有些元素,诸如 <li>、<tr> 和 <option>,只能出现在其它某些特定的元素内部。
这会导致我们使用这些有约束条件的元素时遇到一些问题。例如:

<table><blog-post-row></blog-post-row>
</table>

这个自定义组件 会被作为无效的内容提升到外部,并导致最终渲染结果出错。幸好这个特殊的 is 特性给了我们一个变通的办法:

<table><tr is="blog-post-row"></tr>
</table>

我们看一个例子如下:

<ul id="ul1"><li is="my-li"></li></ul><script type="text/javascript">var Child = {template: '<li>xx!</li>'}new Vue({el: "#ul1",components: {'my-li': Child}})</script>

用 Prop 传递不同值类型

以前只看到了以字符串数组形式列出的 prop
但是,通常你希望每个 prop 都有指定的值类型。这时,你可以以对象形式列出 prop,这些属性的名称和值分别是 prop 各自的名称和类型

props: {title: String,likes: Number,isPublished: Boolean,commentIds: Array,author: Object
}

我们看下面这个例子:

    <child id="div1" message="hello!"></child><script type="text/javascript">Vue.component('child', {props: {'message':String},template: '<span>{{ message }}</span>'})new Vue({el: "#div1",})</script>

效果输出如下:

hello!

用 Prop通过 v-bind 动态赋值

  <div id="div2"><input type="text" v-model="parentMsg"><component1 v-bind:msg="parentMsg"></component1></div><script type="text/javascript">Vue.component("component1", {props: ["msg"],template: "<span>{{msg}}</span>"})new Vue({el: "#div2",data: {parentMsg: "父组件初始化数据"}})</script>

效果图如下:

父组件初始化数据  父组件初始化数据

用 Prop传递对象的所有属性

方式一我们可以使用v-bind:prop-name进行对象属性的传递

<div id="div3"><todo-item v-bind:text="todo.text" v-bind:complete="todo.isComplete"></todo-item></div><script type="text/javascript">Vue.component("todo-item", {props: ["text", "complete"],template: "<span>{{text}}{{complete}}</span>"})new Vue({el: "#div3",data: {todo: {text: 'Learn',isComplete: "Vue"}}})</script>

方式二我们可以使用不带参数的 v-bind

 <div id="div4"><todo-item v-for="item in todo" v-bind:todo="item"></todo-item></div><script type="text/javascript">Vue.component("todo-item", {props: ["todo"],template: "<span>{{todo}}</span>"})new Vue({el: "#div4",data: {todo: {text: 'Learn',isComplete: "Vue"}}})</script>

输出效果如下:

LearnVue

用 Prop传递对象数组

<div id="div5"><todo-item v-for="item in todo" v-bind:todo="item"></todo-item></div><script type="text/javascript">Vue.component("todo-item", {props: ["todo"],template: "<span>{{todo.text}},{{todo.isComplete}}</span>"})new Vue({el: "#div5",data: {todo: [{text: 'Learn',isComplete: "Vue"}, {text: 'yes',isComplete: "no"}]}})</script>

输出效果如下:

Learn,Vueyes,no

用 Prop传入一个数字

   <div id="div6"><comp todo="1+23"></comp><!-- 这里用了动态语法,传递的值会通过js的表达式计算,传递的是数字 --><comp v-bind:todo="1+23"></comp></div><script type="text/javascript">Vue.component("comp", {props: ["todo"],template: "<span>{{todo}}</span>"})new Vue({el: "#div6",})</script>

输出如下:

1+23 24

单向数据流

所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。

额外的,每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你不应该在一个子组件内部改变 prop。如果你这样做了,Vue 会在浏览器的控制台中发出警告。

这里有两种常见的试图改变一个 prop 的情形:

1、这个 prop 用来传递一个初始值;这个子组件接下来希望将其作为一个本地的 prop 数据来使用。在这种情况下,最好定义一个本地的 data 属性并将这个 prop 用作其初始值

 <div id="div7"><input type='text' v-model="msg"><child v-bind:message='msg'></child></div><script type="text/javascript">var tmp = 0;Vue.component('child', {props: ['message'],template: '<p>message:{{ message}} --tmp:{{tmp}}</p>',data: function () {return { tmp: this.message }},})new Vue({el: '#div7',data: {msg: '我是msg'}})</script>

效果图如下:
在这里插入图片描述

2、这个 prop 以一种原始的值传入且需要进行转换。在这种情况下,最好使用这个 prop 的值来定义一个计算属性

<div id="div8"><input type='text' v-model="msg"><child v-bind:message='msg'></child></div><script type="text/javascript">Vue.component('child', {props: ['message'],template: '<p>message:{{ normalizedSize}} </p>',computed: {normalizedSize: function () {return this.message += "_str"}}})new Vue({el: '#div8',data: {msg: '我是msg'}})</script>

在这里插入图片描述

Prop 验证

我们可以为组件的 prop 指定验证要求,例如你知道的这些类型。如果有一个需求没有被满足,则 Vue 会在浏览器控制台中警告你

为了定制 prop 的验证方式,你可以为 props 中的值提供一个带有验证需求的对象,而不是一个字符串数组。例如:

 <div id="app"><my-child :num="100" :msg="'sdf'" :object="{a:'a'}" :cust="100"></child></div><script type="text/javascript">Vue.component('my-child', {props: {// 基础类型检测 (`null` 意思是任何类型都可以)num: Number,// 多种类型propB: [String, Number],// 必传且是字符串msg: {type: String,required: true},// 数字,有默认值num1: {type: Number,default: 1000},// 数组/对象的默认值应当由一个工厂函数返回object: {type: Object,default: function () {return { message: 'hello' }}},// 自定义验证函数cust: {validator: function (value) {return value > 10}}},template: `<div><p>{{ num }}</p><p>{{ msg }}</p><p>{{ num1 }}</p><p>{{ object }}</p><p>{{ cust }}</p></div>`})new Vue({el: "#app"});</script>

效果输出如下:

100sdf1000{ "a": "a" }100

这篇关于vue学习十一(全局局部组件、prop传不同值、 v-bind 动态赋值、单向数据流、prop校验)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125123

相关文章

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,