ホームページ > ウェブフロントエンド > フロントエンドQ&A > vue オブジェクトの listen プロパティは何を表しますか?

vue オブジェクトの listen プロパティは何を表しますか?

青灯夜游
リリース: 2022-12-14 19:46:59
オリジナル
2558 人が閲覧しました

vue オブジェクトの listen 属性は「watch」で表されます。いわゆる監視とは、組み込みオブジェクトの状態やプロパティの変化を監視して対応することであり、プロパティの監視とは、他のデータの変化を監視できることを意味します。 Vue で監視属性を記述する方法は 2 つあります: 1. "new Vue()" で監視設定を渡す; 2. "vm.$watch" を通じて監視します。

vue オブジェクトの listen プロパティは何を表しますか?

#このチュートリアルの動作環境: Windows7 システム、vue3 バージョン、DELL G3 コンピューター。

watch Listening プロパティ

いわゆるモニタリングとは、組み込みオブジェクトの状態やプロパティの変化を監視し、応答することです。 、 listen プロパティ 、これは、他のデータの変化を監視できることを意味します。

必要な派生データが非同期で処理される場合がありますが、現時点では、計算されたプロパティは使いにくいです (非同期を処理できません)。別のオプションを使用できます: watch

watch: listen 属性; 監視されるのはデータの属性です。属性が変更されると、いくつかの処理が行われます。

書き方は 2 つあります。次のように listen 属性を指定します。

  • new Vue()watch 設定に渡します。

  • vm.$watch を通じて監視します。

具体的な例を見てみましょう。

    new Vue() で監視設定を渡します。
    <div>
        <div>今天天气很{{info}}</div>
<br>
        <button>切换天气</button>
    </div>
    <script>
        Vue.config.productionTip = false;

        new Vue({
            el:"#root",
            data:{
                isHot:true
            },
            computed:{
                info(){
                    return this.isHot ? "炎热" : "凉爽";
                }
            },
            methods:{
                changeWeather(){
                    this.isHot = !this.isHot;
                }
            },
            watch:{
                isHot:{
                    immediate:true,
                    handler(newValue,oldValue){
                        console.log("监听isHot:","newValue="+newValue,"oldValue="+oldValue);
                    }
                }
            }
        })
    </script>
ログイン後にコピー
watch isHot の場合、次のようにコールバック関数ハンドラのみが提供されます:

watch:{
    isHot:{
        handler(newValue,oldValue){
            console.log("isHot:newValue="+newValue,"oldValue="+oldValue);
        }
    }}
ログイン後にコピー
これは次の形式に短縮できます:

watch:{
    isHot(newValue,oldValue){
        console.log("isHot:newValue="+newValue,"oldValue="+oldValue);
    }}
ログイン後にコピー
    vm .$watch を介して監視します。
    <div>
        <div>今天天气很{{info}}</div>
<br>
        <button>切换天气</button>
    </div>
    <script>
        Vue.config.productionTip = false;

        const vm = new Vue({
            el:"#root",
            data:{
                isHot:true
            },
            computed:{
                info(){
                    return this.isHot ? "炎热" : "凉爽";
                }
            },
            methods:{
                changeWeather(){
                    this.isHot = !this.isHot;
                }
            }
        })

        vm.$watch("isHot",{
            immediate:true,
            handler(newValue,oldValue){
                console.log("监听isHot:","newValue="+newValue,"oldValue="+oldValue);
            }
        })
    </script>
ログイン後にコピー
watch isHot の場合、次のようにハンドラーのみが提供されます:

vm.$watch("isHot",{
    handler(newValue,oldValue){
        console.log("isHot:newValue="+newValue,"oldValue="+oldValue);
    }})
ログイン後にコピー
これは次の形式に省略できます:

vm.$watch("isHot",function(newValue,oldValue){
    console.log("isHot:newValue="+newValue,"oldValue="+oldValue);})
ログイン後にコピー
ブラウザを開いて、テスト。


vue オブジェクトの listen プロパティは何を表しますか?

#ディープモニタリング
    <div>
        <div>a的值是{{numbers.a}}</div>
        <button>点我加1</button>
    </div>
    <script>
        Vue.config.productionTip = false;

        new Vue({
            el:"#root",
            data:{
                numbers:{
                    a:1,
                    b:1
                }
            },
            watch:{
                "numbers.a":{
                    handler(newValue,oldValue){
                        console.log("a:","newValue="+newValue,"oldValue="+oldValue);
                    }
                },
                "numbers":{
                    deep:true,
                    handler(newValue,oldValue){
                        console.log("numbers发生了变化!");
                    }
                }
            }
        })

    </script>
ログイン後にコピー
マルチレベル構造の特定の属性をモニタリングします。

numbers.a

のように、number オブジェクトのプロパティが変更されると、Vue はコールバック ハンドラーをリッスンして実行します。 "numbers":{deep:true}
など、マルチレベル構造のすべてのプロパティを監視します (ディープ モニタリング)。numbers オブジェクトのプロパティが変更されると、Vue はそれをリッスンすることもできます。そして実行はハンドラーに戻ります。

#リスニング プロパティと計算プロパティ

リスニング プロパティを使用して実装する
    <div>
        姓:<input><br><br>
        名:<input><br><br>
        全名:<span>{{fullName}}</span>
    </div>
    <script>
        new Vue({
            el:"#root",
            data:{
                firstName:"张",
                lastName:"三",
                fullName:"张-三"
            },
            watch:{
                firstName(val){
                    this.fullName = val + this.lastName;
                },
                lastName(val){
                    this.fullName = this.firstName + "-" + val;
                }
            }
        })
    </script>
ログイン後にコピー
計算プロパティを使用して実装
    <div>
        姓:<input><br><br>
        名:<input><br><br>
        全名:<span>{{fullName}}</span>
    </div>
    <script>
        new Vue({
            el:"#root",
            data:{
                firstName:"张",
                lastName:"三"
            },
            computed:{
                fullName(){
                    return this.firstName+"-"+this.lastName;
                }
            }
        })
    </script>
ログイン後にコピー
計算プロパティを完成させることができれば、リッスン プロパティも間違いなく完成できることがわかります。 。 ただし、属性の監視によって達成できることは、データ変更時の非同期操作の実行など、属性の計算によって必ずしも達成できるわけではありません。具体的な例を見てみましょう。firstName が変更されると、fullName が変更されるまで 1 秒待機します。
    <div>
        姓:<input><br><br>
        名:<input><br><br>
        全名:<span>{{fullName}}</span>
    </div>
    <script>
        new Vue({
            el:"#root",
            data:{
                firstName:"张",
                lastName:"三",
                fullName:"张-三"
            },
            watch:{
                firstName(val){
                    setTimeout(() => {
                        this.fullName = val + "-" + this.lastName;
                    },1000);
                },
                lastName(val){
                    this.fullName = this.firstName + "-" + val;
                }
            }
        })
    </script>
ログイン後にコピー


[vue]メソッド、計算プロパティ、データ監視

では、計算プロパティと監視プロパティも比較しました。ほとんどの場合、計算プロパティの方が適切ですが、データ変更時に非同期操作を実行する必要がある場合は、リスナー プロパティの方が便利です。

さらに、再度お勧めします:

Vue によって管理される関数は通常の関数として作成し、関数のこの点が Vue になるようにするのが最善です。実例。
  • タイマー関数、ajax コールバック関数、プロミス関数など、Vue によって管理されない関数は、アロー関数として記述するのが最適です。アロー関数には独自の this がないためです。
  • [関連する推奨事項:
  • vuejs ビデオ チュートリアル

Web フロントエンド開発]

以上がvue オブジェクトの listen プロパティは何を表しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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