検索

ホームページ  >  に質問  >  本文

angular.js - angularjs のカスタム ディレクティブ スコープの問題

angularjs のカスタム ディレクティブのスコープの値は {} で、これにより分離されたスコープが作成されますが、親スコープのプロパティには引き続きアクセスできます。何が起こっているのでしょうか? (バインディング戦略が実装される前に、分離スコープは親スコープのプロパティにアクセスできないようにする必要があります)

淡淡烟草味淡淡烟草味2808日前824

全員に返信(4)返信します

  • 巴扎黑

    巴扎黑2017-05-15 17:09:33

    まず第一に、この例では、scope 属性に値を割り当てていません。スコープ属性には、true、false、{} の 3 つの値があります。 false はデフォルト値です。

    デフォルト、false。このとき、子スコープと親スコープは一つであり、scope.$$idの値は同じになります。

    が true の場合、新しいスコープが作成され、scope.$$id の値は異なります。ただし、このスコープは親スコープから継承します。 これは、ネイティブ JS スコープ チェーンの特性と同じです。子スコープは親スコープのプロパティとメソッドにアクセスできますが、親スコープは子スコープのプロパティとメソッドにアクセスできません。

    が {} の場合、それは本当の孤立です。現時点では、カスタム ディレクティブのスコープは親スコープとは関係ありません。しかし、それでも親スコープのプロパティ メソッドにアクセスしたい場合は、{} で対応するプロパティを設定するだけでよいでしょうか。具体的な設定方法についてはGoogle Baiduを参照してください。

    返事
    0
  • 天蓬老师

    天蓬老师2017-05-15 17:09:33

    同じコントローラーではアクセスできますが、異なるコントローラーではアクセスできません

    返事
    0
  • ringa_lee

    ringa_lee2017-05-15 17:09:33

    隔離されていない場合は、スコープを追加します。{}

    返事
    0
  • phpcn_u1582

    phpcn_u15822017-05-15 17:09:33

    スコープを分離するには 2 つの方法があります:

    リーリー

    返事
    0
  • キャンセル返事