angularjs 的模型没法绑定到隐藏域(input hidden)

描述一下问题:git

在操做表单中的隐藏域的时候发现angularjs的模型没法绑定,好比:angularjs

<input type="hidden" name="someData" ng-model="data" />

在网上找到了解决办法,特地记录;原文:http://stackoverflow.com/questions/18446359/angularjs-does-not-send-hidden-field-valuegithub

这种一般状况下data一直没法取到值;express

有如下几种解决办法:ui

1,this

<input type="text" name="someData" ng-model="data" style="display: none;"/>

2,spa

<input type="hidden" required ng-model="data.userid" ng-init="data.userid=pivot.id" />

3,.net

<input type="hidden" name="someData" value="{{data}}" />

4,code

<input type="hidden" name="someData" ng-value="data" />

 

最优回答以下:blog

You cannot use double binding with hidden field. The solution is to use brackets :

<input type="hidden" name="someData" value="{{data}}" /> {{data}}

EDIT : See this thread on github : https://github.com/angular/angular.js/pull/2574

EDIT:

Since Angular 1.2, you can use 'ng-value' directive to bind an expression to the value attribute of input. This directive should be used with input radio or checkbox but works well with hidden input.

Here is the solution using ng-value:

<input type="hidden" name="someData" ng-value="data" />

Here is a fiddle using ng-value with an hidden input: http://jsfiddle.net/6SD9N

相关文章
相关标签/搜索