ホームページ > ウェブフロントエンド > Vue.js > vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

WBOY
リリース: 2021-12-27 19:07:03
転載
1979 人が閲覧しました

この記事では、複数の vue オブジェクト、グローバル コンポーネント、ローカル コンポーネントをインスタンス化する方法、親から子に値を渡す方法など、vue コンポーネントに関する知識を提供します。皆様のお役に立てれば幸いです。

vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

#コンポーネント アプリケーションの最初の紹介

複数の Vue オブジェクトをインスタンス化する

Use new複数の Vue オブジェクトを作成し、それらに名前を付けます。これらは変数を通じて相互にアクセスできます

例: オブジェクト 2 はオブジェクト 1 の name 変数を変更します

<!-- 第一个根元素 -->
<div>这里是:{{name}}</div> 

<!-- 第二个根元素 -->
<div>
    <p>这里是:{{name}}</p>
<br>
    <button>change-one-name</button>
    <!-- 点击后修改vue-app-one的name值-->
</div>
ログイン後にコピー
 // 第一个vue对象var one = new Vue({
    el:"#vue-app-one",
    data:{
        "name":"ccy1"
    }})

 // 第二个vue对象var two = new Vue({
    el:"#vue-app-two",
    data:{
        "name":"ccy2"
    },
    methods:{
        // 修改vue-app-one的name为'ccy333'
        changeName:function(){
            one.name = 'ccy333'
        }
    }})
ログイン後にコピー
効果: クリックした後、「ccy1」を「ccy333」に変更します。

vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

グローバル コンポーネント

定義と使用

    #グローバル コンポーネントを定義します。コンポーネントに名前を付ける必要があります。呼び出すときは、コンポーネント名をラベル名として使用します。これはカスタム ラベルと同等です。このラベルには多くのサブ HTML タグを含めることができます。
  • これらsub-html タグは、コンポーネントの template 属性で定義されており、コンポーネントが呼び出されるたびに、テンプレート内のタグがレンダリングされます。
  • # テンプレート内のルート要素は 1 つだけである必要があります
  • コンポーネントでは、
  • data は関数です
  • 、データを返します #これを使用して、data で定義されたデータを呼び出すこともできます
  • 例:
コンポーネントの定義:

① my-component という名前のコンポーネントを定義します ② データが含まれます: 名前とメソッド:changeName

③ レンダリングされた HTML 効果には A ボタンを含む p タグがあり、ボタンがクリックされると名前が変更されます
④ 命名規則: キャメルケース (キャメルケース命名方法) およびケバブケース (ダッシュ区切り命名) )



ラベルとして記述する場合、大文字の名前を小文字に変更する必要があり、前後の 2 つの部分をクロスバーで接続する必要があります。たとえば、コンポーネントを定義する場合
myComponent

という名前を付け、ラベルとして記述する場合は、 my-component
  • > として記述する必要があります。 ; 水平方向の定義時にコンポーネントに名前を付けるための bar メソッド; 定義時に myComponent を使用し、ラベルに my-component
  • > を使用すれば問題ありません、システムは自動的に ## を識別します
  • #
    // 自定义的全局组件my-component// template中只有一个根元素p标签,里面包含一个button按钮Vue.component('my-component',{
        template:`<p>
            我的名字是:{{name}}
            <button>btn</button>
            </p>`,
        data(){
            return {
                name:'ccy'
            }
        },
        methods:{
            changeName:function(){
                this.name = '安之'
            }
        }})// vue对象1new Vue({
        el:"#vue-app-one",})// vue对象2new Vue({
        el:"#vue-app-two",})
    ログイン後にコピー
    使用コンポーネント:
  • ① vue オブジェクトに対応するルート要素の下で ## を使用します (el はタグを指定します) # ②グローバルコンポーネントなので、任意の vue オブジェクトの下で使用できます ③ コンポーネントは再利用可能で、vue オブジェクトの下で複数回使用でき、コンポーネントは互いに独立しています

    <p>
        <my-component></my-component>
        <my-component></my-component></p> <p>
        <my-component></my-component></p>
    ログイン後にコピー

    効果:

    data は関数です
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)vue オブジェクトでは、data 属性値はオブジェクトです。例:

    ただし、グローバル コンポーネントでは、同じデータが複数の vue オブジェクトで使用される可能性があります。各オブジェクトがデータの個別のコピーを保持していない場合、特定の vue オブジェクトがmodified データ内の変数が削除されると、他の vue オブジェクトはデータを取得するときに影響を受けます;

    上記の例をケースとして使用すると、コンポーネント内のデータがオブジェクト (参照) の場合、その他の場所は変更されません。両方の Vue オブジェクトは同じ名前変数を共有します。Vue オブジェクトの 1 つで名前データを変更すると (つまり、任意のボタンをクリックすると)、もう一方のオブジェクトによって取得される名前も変更されます (「ccy」他のボタンも変更されます。「Anzhi」に変更されました)

    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション) したがって、データの独立性を確保するために、つまり、
    各インスタンスは返されたオブジェクトの独立したコピーを維持できます

    、データは各インスタンスが新しく作成されたデータのコピーを返し、異なる vue オブジェクトによって取得されたデータは相互に影響しません

    vscode では、コンポーネント内のデータは許可されませんオブジェクトである場合、エラーが報告されます。

    [Vue warn]: 「data」オプション

    インスタンスごとの値を返す関数

    である必要があります。コンポーネントの定義。

    ローカル コンポーネント

    ローカル コンポーネントは、vue オブジェクトに登録されます。

    登録されたローカル コンポーネントはこのローカル コンポーネントを使用できます

    • 例:
    • ローカル コンポーネント定義
    • :
    // template仅一个根元素:ulvar msgComponent = {
    	 // 数据是自身提供的 (hobbies)
        template:`
    ログイン後にコピー
    • {{hobby}}
    `,     data(){         return {             hobbies:['看剧','看动漫','吃好吃的']         }     }}

    ローカル コンポーネントを登録します:

    // 仅由注册过该局部组件的vue对象才能使用,此处为p#vue-app-one// 注意命名规范,components中对象的key将会被作为标签名,多个单词拼接的命名需使用横杆法// 可以写成msg-component,此处直接简化了命名为msg,new Vue({
        el:"#vue-app-one",
        components:{
            "msg": msgComponent    }})
    ログイン後にコピー

    HTML ファイル内で

    を使用します:

    <p>
        </p><p>这里是vue-app-one</p>
        <mycomponent></mycomponent>
        <mycomponent></mycomponent>
        <p>我的爱好:</p>
        <msg></msg> <!--使用局部组件-->
    ログイン後にコピー

    効果: 赤のボックスで囲まれた部分はローカル コンポーネントによってレンダリングされます


    親から子に値/参照を渡す: propvue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

    静的値の受け渡し

    サブコンポーネントの作成:

    ##
    var titleComponent = {
        props:["title"],
        template:`<p>{{title}}</p>`
        // 所需要的数据title由父组件提供}
    ログイン後にコピー

    在父组件的components属性中注册子组件:

    new Vue({
        el:"#vue-app-one",
        components:{
            "msg": msgComponent,
            "titleComponent":titleComponent    },})
    ログイン後にコピー

    在父组件上使用子组件:

    <!-- p#vue-app-one为父组件 --><p>
        </p><p>这里是vue-app-one</p>
        <mycomponent></mycomponent>
        <mycomponent></mycomponent>
    	<!--使用子组件title-component,并传值"我的爱好:"给子组件-->
        <title-component></title-component>
        <msg></msg>
    ログイン後にコピー

    效果:红框标记处就是父向子传值并展示

    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

    动态传值:v-bind

    定义子组件:

    var titleComponent = {
        props:["title"],
        template:`<p>{{title}}</p>`}
    ログイン後にコピー

    在父组件的components属性中注册子组件:

    new Vue({
        el:"#vue-app-one",
        components:{
            "msg": msgComponent,
            "titleComponent":titleComponent    },
        data(){
            return {
                title:"my hobbies are ",
            }
        }})
    ログイン後にコピー

    使用子组件,通过绑定父组件data中的变量title来实现动态传值:

    <!-- p#vue-app-one为父组件 --><p>
        </p><p>这里是vue-app-one</p>
        <mycomponent></mycomponent>
        <mycomponent></mycomponent>
        <!-- 动态绑定title -->
        <title-component></title-component>
        <msg></msg>
    ログイン後にコピー

    效果:红框处就是动态绑定获取数据的展示
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)
    传递数组等复杂数据时,也可以使用v-bind来动态传值,如:
    需要向子级传递hobbies数组,在vue实例对象(父)中创建数据hobbies

    new Vue({
        el:"#vue-app-one",
        components:{
            "msg": msgComponent,
            "titleComponent":titleComponent    },
        data:{
            title:"my hobbies are ",
            hobbies:['看剧','看动漫','吃好吃的'], //需要向子组件传递的数据
        }})
    ログイン後にコピー

    定义子组件

    var msgComponent = {
        template:`
                <p>{{hobby}}</p>            `,
        props:["hobby"],
        data(){
            return {   
            }
        }}
    ログイン後にコピー

    使用子组件

    <!-- p#vue-app-one为父组件 --><p>
        </p><p>这里是vue-app-one</p>
        <mycomponent></mycomponent>
        <mycomponent></mycomponent>
        <title-component></title-component>
        <!-- 动态传值:hobbies -->
        <msg></msg>
    ログイン後にコピー

    效果:
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)
    跳回“一点想法”处

    子向父:事件传值$emit

            子组件不能通过prop向父组件传递数据,需要使用事件向父组件抛出一个值,告知父组件我需要实现一个功能,由父组件处理这个事件

    例子:点击按钮,改变名称chinesename
    (由于data变量名不支持chinese-name形式,花括号里不支持chineseName形式,所以这里我都用了小写,此处记录一下,日后学到了新知再来填坑)

    先在父组件的data中定义chinesename的初始值:

    new Vue({
        el:"#vue-app-one",
        data:{
             chinesename:"anzhi" // chinesename初始值
        }})
    ログイン後にコピー

    创建子组件,并注册事件change-name(就像click事件一样,需要让系统能够辨认这是一个事件并监听,当事件被触发时,执行某项约定好的操作):

      Vue.component('blog-post', {
        props: ['chinesename'],
        template: `
          <p>
            </p><h3>{{ chinesename }}</h3>
            <button>
                修改名字
            </button>
              `
        // blog-post组件包含一个h3,显示chinesename,和一个按钮
        // 点击这个按钮,触发change-name事件,将"ruosu"作为参数传递给指定的处理函数onChangeName
      })
    ログイン後にコピー

    在父组件中使用子组件,定义change-name的处理函数为onChangeName:

    <p>
        </p><p>这里是vue-app-one</p>
    	<!-- v-bind:通过prop给子组件传递chinesename的初始值 -->
    	<!-- v-on:子组件通过$emit给父组件传递新的chinesename的值 -->
    	<p>
    	      <blog-post></blog-post>
    	 </p>
    ログイン後にコピー

    在父组件处定义事件处理函数onChangeName:

    new Vue({
        el:"#vue-app-one",
        data:{
              chinesename:"anzhi"
        },
        methods:{
            onChangeName:function(value){
            	// 将chinesename换成传递过来的数据
                this.chinesename=value        }
        }})
    ログイン後にコピー

    效果:
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

    一点想法

    关于父子组件的区分,在此写一点总结,还是日后学了新知识再来填坑 ┗|`O′|┛ 嗷~~

          官网中没有很明确指明两者的定义和区别,在网上搜了一圈,觉得比较多人认可并且好理解的是:

    • el指定的根元素为父组件(使用之处为父组件)
    • vue实例对象也可看做组件

          在前面这些父子传值的例子中,我们可以看到,对于局部组件,我们会在某个html根元素中注册并使用,所以此时el指定的根元素在html文件中是这个局部组件的父组件,局部组件在html使用时便是这个父组件的一份子,承担数据传输的责任
    跳转到父向子动态传值案例

    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)

          再用绕口令说一波,即:title-component组件定义处与使用处,两者身份是不一样的,在定义处,它是局部组件,也是子组件,需注册才能使用;在使用处,它是根元素的包含一部分,根元素为父组件,而“它”,承担着父组件与子组件数据沟通的重任

    这个总结在全局组件情况下也适用,使用该全局组件的根元素是父组件,如上面的子向父传值的案例,p#vue-app-one是父组件,作为父子组件沟通的桥梁,全局组件blog-post为子组件
    跳转到子向父案例

    图示:
    vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)


    如果是子组件又嵌套了子组件,被嵌套的组件是子子组件,以此类推

    スキャフォールディングを使用してプロジェクトを作成し、コンポーネントを使用して値を渡す

    CLI スキャフォールディングのインストール手順については、私の記事を参照してください。 CLI スキャフォールディングを使用したプロジェクトの作成は簡単かつ迅速です。特に、ページ コンテンツとデータ転送は .vue ファイルに記述する必要があり、各 vue ファイルはモジュールです。
    各モジュール (コンポーネント) を合理的に組み立てることで特定の機能を完成させますが、コンポーネント間の連携と親子間の値の伝達の役割がより明確になります。各 vue ファイルをコンポーネントとみなすことができ、必要に応じてページをナビゲーション バー、中間コンテンツ、下部などのいくつかの部分に分割できます。各部分の実装は、ページ表示やデータ取得などのさまざまなサブコンポーネントに分散されています。

    例: カスタマイズされたブログ ページ:

    • メイン ページは、ナビゲーション バー、中央部分を含む vue-app メイン コンポーネントで構成されます。 、下部のバー

    • ナビゲーション バーは vue-header サブコンポーネントによって完成されます

    • ##中央のコンテンツは機能に従って分割されています

        ブログの追加: addBlob サブコンポーネント コンポーネント
      • ブログの表示: showBlob サブコンポーネント
      • ブログの変更:modifyBlob サブコンポーネント
      • クリックして単一のブログを表示しますcontent: singleBlob subcomponent
    • 下部の情報バーは vue-footer によって完成されます

      メイン ページに加えて、他のサブパーツとコンポーネントが機能に従って分割されていますメイン ページの表示を支援するため

    個人ブログの親から子への値の受け渡しの概略図は次のとおりです。

    各サブ関数は次のとおりです。さまざまなコンポーネントで構成されており、これらのコンポーネントは、より大きな機能コンポーネントに結合されます。
    • クリックして、単一のブログを表示し、ブログを変更します。両方のコンポーネントは、それに応じて表示および操作するために、メイン ページからブログ ID を取得する必要があります。これは典型的な親から子への値の転送です。

    • vue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)
    • [関連する推奨事項: "
    vue.js チュートリアル

    "]

    以上がvue コンポーネントの使用を開始するには 1 時間 (推奨コレクション)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    ソース:csdn.net
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    最新の問題
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート