angularjs - ng-switch does not bind ng-model

前端 未结 3 1523
走了就别回头了
走了就别回头了 2020-11-29 07:48

I have this repro http://embed.plnkr.co/nVCmukG5abpi1Y4ZHkrq that show when I click \'Title3\' and enter a value in text box although the entered value shows reflected in th

相关标签:
3条回答
  • 2020-11-29 08:21

    This is a scope inheritance problem due to ng-switch creating its own scope.

    One recommendation made often is always to use a dot on models. The reason is that when the controller scope item is an object and not a primitive, sub scopes will create a reference to the initial object. If model is a primitive it will not update the original.

    For example:

    <input ng-model="test.value" placeholder="pre" type="text" />
    
    $scope.test={value:''}
    

    Another approach is to use $parent in html model markup:

    <input ng-model="$parent.test" placeholder="pre" type="text" />
    

    Using the dot methodology is a good practice to avoid these issues as you don't need to think about deeper nested scopes.

    Demo using test.value as model: http://plnkr.co/edit/CkiF55bLXsYzR6ZjcrJp?p=preview

    Reference regarding dot in models(valuable reading): https://github.com/angular/angular.js/wiki/Understanding-Scopes

    0 讨论(0)
  • 2020-11-29 08:26

    I've encountered similar issue, and I've solved by creating a scope variable in the controller and used that with in ng-include and ng-switch. This way if you've deep nested ng-include's with in ng-switch and it goes on, we can still directly use that scope variable.

    As all child scopes (here, ng-include/ng-switch) extends from parent scope (generally, controllers scope), we can access parent scope directly from with in these child scopes without a problem.

    Using $parent will require to write like $parent.$parent.$parent.someProp

    Example Plunk: http://plnkr.co/edit/8UGH7nUpFmATiXfkYSwr?p=preview

    0 讨论(0)
  • 2020-11-29 08:43

    This is because you're actually creating a child scope inside of the ng-switch. So another test property exists on a scope belonging to the ngSwitch directive. It will initially show the value from it's parent scope, but when you edit it, because it is a primitive, it only edits the value on the child, not the parent. Prototypical inheritance does not come into play here (but that's what we need).

    When you click the button the button is alerting/console.logging the property on the parent scope... which the child cannot change.

    To fix this use $parent.test on your ng-model attribute in your ngSwitch:

    a snippet:

    <span class="pew"  ng-switch-when="title2">
      <input ng-model="$parent.test" placeholder="pre" type="text" />
      {{test}}
    </span>
    

    And here's a fork of your plunker showing it in action.

    0 讨论(0)
提交回复
热议问题