2

这是我的 HTML / Angular:

<form ng-submit="ctrl.add()">
    <div class="form-group">
        <label>Username</label>
        <input type="text" ng-model="ctrl.user.username"> 
    </div>

    <div class="form-group">
        <label>Password</label>
        <input type="password" ng-model="ctrl.user.password" required>
    </div>

    <div class="form-group">
        <label>Email</label>
        <input type="email" ng-model="ctrl.user.email" required> 
    </div>

    <div class="form-group">
        <label>Country</label>
        <input type="text" ng-model="ctrl.user.userextended_set.country" ng-trim="false"> 
    </div>
    <input type="submit" value="Register" ng-disabled="myForm.$invalid"> 
</form>

问题是,当用户在没有填写“用户名”或“国家”部分的情况下点击提交时,AngularJS 会向后端发送一个 JSON 对象,其中只有“电子邮件”和“密码”作为字典中的键。字典中不存在“用户名”和“国家/地区”键(从现在开始,将“国家/地区”字段称为“userextended_set”,因为它在我的 ng-model 中被称为该字段)。如何让 AngularJS 不完全忽略它,并至少发送值为“null”的键?

编辑:这很奇怪,因为即使我在“userextended_set”字段上有 ng-trim="false",如果我最初提交表单时没有在“userextended_set”中填写任何内容,AngularJS 也不会发送“userextended_set”作为 JSON 中的键目的。但是如果我在“userextended_set”中输入一些内容然后删除它,然后点击提交,JSON 会发送“userextended_set”作为键。

4

1 回答 1

0

尝试将属性添加到输入字段:

ng-trim="false"
于 2015-11-10T08:17:18.867 回答