ホームページ >ウェブフロントエンド >jsチュートリアル >vue2.X コンポーネントのサンプル チュートリアルを共有する
焦点: 親コンポーネントと子コンポーネント間の通信
写真を見て話してください:
Props を渡す
子コンポーネント自体は親コンポーネントから分離されており、宣言された props 属性を通じて受け取ります子コンポーネントのデータ。
親コンポーネントのデータが更新されると、それに応じて子コンポーネントのプロパティも更新されます。
このデータフローは一方向です。
v-on
を使用してリスナーをバインドし、対応するイベントをトリガーしますv-on
绑定监听,触发对应事件;
以上为通用语,具体分析
子组件可以接收一个字符串,在子组件内部可以用{{label}}使用
<v-input label="姓名"></v-input>
子组件可以接收动态参数
<input v-model="msg" /><v-profile :message="msg"></v-profile>
子组件接收到数据之后想处理一下不小心改了怎么办?
给prop创建一个副本(建议深拷贝),处理副本,不动prop;
父组件的数据改变后,子组件的prop会自动更新,但是这个prop的副本不会啊?
使用watch监听这个prop,改变时更新副本;
子组件的prop副本改变了想要通知父组件怎么办?
使用watch监听这个副本,改变时向外抛出自己的内部触发的事件;
。。。
其实以上???在2.3有了更好的方法,之前的就是看看。
.sync修饰符
***父组件*** <input v-model="msg" /> <v-profile :message.sync="msg"></v-profile> ***子组件***$.emit('update:message',newValue)
我是用了一下然后喜闻乐见的修改成功了,但是打开控制台有报错!!!
vue.esm.js?65d7:434 [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "message"
子组件想要触发父组件可以emit(父组件需要监听才会触发),父组件触发子组件事件呢?
通过在引用的子组件上使用ref属性实现父组件调用子组件的方法以及属性
但是!$refs
只在组件渲染完成后才填充,并且它是非响应式的。它仅仅作为一个直接访问子组件的应急方案——应当避免在模版或计算属性中使用 $refs
。
使用空的vue实例作为中央事件总线
var bus = new Vue();// 触发组件 A 中的事件bus.$emit('id-selected', 1)// 在组件 B 创建的钩子中监听事件bus.$on('id-selected', function (id) { // ...})
考虑vuex
首先,在父组件中给子组件标签中间放置内容是无效的。然后slot出场。
白话版本:
<span style="color: #000000">匿名slot: slot标签存在与子组件template中; 子组件在父组件中使用的时候,子组件标签中的结构会在编译后替换子组件的slot标签;<br> 如果子组件中没有slot,则父组件中子组件标签中的内容会消失; 具名slot: 顾名思义,是具有name属性的slot标签;并有匿名组件的特性(以上); 子组件在父组件中使用的时候,子组件中的结构中会有某些标签拥有slot属性并赋值,这些会在编译后替换子组件的相应slot标签;</span>
一句话解释:主要的内容是写在父组件中的子组件标签中,编译后插入子组件的相应位置
讲真,说到这里我自己都不明白要slot干嘛。
官方讲解入口
官方给了个布局的例子:
<div class="container"> <header><slot name="header"></slot> </header> <main><slot></slot> </main> <footer><slot name="footer"></slot> </footer></div>
<app-layout> <h1 slot="header">这里可能是一个页面标题</h1> <p>主要内容的一个段落。</p> <p>另一个主要段落。</p> <p slot="footer">这里有一些联系信息</p> </app-layout>
<br>
通过使用保留的 <component>
元素,动态地绑定到它的 is
<component v-bind:is="currentView" :data1="data1" :data2="data2"> <!-- 组件在 vm.currentview 变化时改变! --> </component>🎜🎜🎜🎜 サブコンポーネントは動的パラメータを受け取ることができます🎜🎜🎜🎜
<br>🎜🎜データを受信した後に誤って変更してしまい、それを処理したいと思っていませんか? 🎜🎜🎜🎜 プロップのコピーを作成し (ディープコピーが推奨されます)、コピーを処理して、プロップを変更しないでください 🎜🎜🎜🎜 親コンポーネントのデータが変更されると、子コンポーネントのプロップが自動的に更新されます。 、しかし、このプロップのコピーはそうではありませんか? 🎜🎜🎜🎜watch を使用してこのプロパティを監視し、変更があった場合にコピーを更新します。🎜🎜🎜🎜子コンポーネントのプロパティのコピーが変更された場合に親コンポーネントに通知したい場合はどうすればよいですか? 🎜🎜🎜🎜watch を使用してこのコピーを監視し、変更されたときに内部的にトリガーされた独自のイベントをスローします。🎜🎜🎜🎜。 。 。 🎜🎜実際上記ですか? ? ? 2.3 にはより良い方法があります。前の方法を参照してください。 🎜🎜.sync modifier🎜🎜rrreee🎜🎜 私はそれを使用し、変更が成功したことを確認して喜んでいたのですが、コンソールを開いたときにエラーが報告されました。 ! ! 🎜🎜🎜rrreee🎜🎜🎜🎜 子コンポーネントが親コンポーネントをトリガーしたい場合、子コンポーネントは発行できます (親コンポーネントはトリガーをリッスンする必要があります)。 🎜🎜🎜🎜参照される子コンポーネントの ref 属性を使用することで、親コンポーネントは子コンポーネントのメソッドとプロパティを呼び出します🎜🎜🎜🎜しかし!
$refs
は、コンポーネントのレンダリングが完了した後にのみ設定され、応答しません。これは、子コンポーネントに直接アクセスするための回避策としてのみ意図されています。テンプレートまたは計算されたプロパティでの $refs
の使用は避けてください。 🎜<component>
要素を使用し、その is
属性に動的にバインドし、動的に切り替えることで、複数のコンポーネントが同じマウント ポイントを使用できるようにします。タブのようなエフェクトを作成するのに非常に適しています🎜🎜🎜🎜rrreee🎜在methods属性中定义一个函数修改currentView即可。
视情况可以配合 keep-alive 避免重新渲染
在子组件上放置activate钩子做切换时的工作:done()
//放到钩子最后,表示执行工作完毕,可以切换组件,配合keep-alive使用,activate钩子只执行一次
子组件接收数据和以往相同,只是这一次都写在了component中,只是如此的话,每个子组件都需要有这些接口(prop)
暂时说到这里,突然得回头看一下react,没时间了,回头会继续。
以上的满基础的(我是新手),有什么不对的求指出,感谢!!!
<br>
以上がvue2.X コンポーネントのサンプル チュートリアルを共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。