2016-06-26 6 views
0

https://plnkr.co/edit/KF9FFdx0sWJkpQ7VKrl2?p=preview ここはplnkrです。誰でも助けてくれますか? 私は自分のタグリストを持っています。これはng-modelとバインドすることができず、ng-keypressを使用して関数呼び出しでタグをオブジェクトの配列としてバインドする必要があります。この形式のjsonファイルに投稿する必要があります。 私はこのようなものが欲しい: 例:タグ付けディレクティブタグをjsonオブジェクトの配列としてバインドする方法と、ng-keypressイベントを使用したタグ付けshoudの作業を行います。

$scope.tags={tag:[ 
    {name:"angular"}, 
    {name:"ruby"}, 
    {name:"pearl"} 
    ]} 
+0

私がよりよく理解してみましょうです。ディレクティブは、各タグを文字列だけでなくjsonオブジェクトとして表示する必要がありますか? –

+0

はいjsonオブジェクトとしてyes – Deepanjan

+0

答えが –

答えて

1

あなたはJSONオブジェクトを受け入れるためにあなたのディレクティブを編集する必要がないだけで

<script> 
    App.directive('dhTag', function($compile) { 
    return { 

     restrict: 'AE', 
     scope: { 
     taglist: '=list', 
     autocomplete: '=autocomplete', 
     display: '=' 
     }, 
     link: function($scope, element, attrs) { 

     $scope.defaultWidth = 490; 
     $scope.tagText = ""; 
     $scope.placeholder = attrs.placeholder; 
     $scope.display = attrs.display; 



     $scope.tagArray = function() { 
      return $scope.taglist || []; 
     }; 


     $scope.addTag = function() { 
      //debugger 
      var tagArray; 
      if ($scope.tagText.length === 0) { 
      return; 
      } 
      tagArray = $scope.tagArray(); 

      for (var i = 0; i < tagArray.length; i++) { 
      if (tagArray[i].name == $scope.tagText) { 
       alert("Tag already exists in the content box!!"); 
       return; 
      } 
      } 

      tagArray.push({ 
      name: $scope.tagText 
      }); 
      $scope.taglist = tagArray; 
      $scope.tagText = ""; 
     }; 


    $scope.deleteTag = function(key) { 
     var tagArray; 
     tagArray = $scope.tagArray(); 
     if (tagArray.length > 0 && $scope.tagText.length === 0 && key === undefined) { 
     tagArray.pop(); 
     } else { 
     if (key !== undefined) { 
      tagArray.splice(key, 1); 
     } 
     } 
     $scope.taglist = tagArray; 
    }; 



    $scope.$watch('tagText', function(newVal, oldVal) { 
     var temp; 
     if (!(newVal === oldVal && newVal === undefined) && temp) { 
     //temp = $("<span>" + newVal + "</span>").appendTo("body"); 
     $scope.inputWidth = temp ? temp.width() : 0; 
     if ($scope.inputWidth < $scope.defaultWidth) { 
      $scope.inputWidth = $scope.defaultWidth; 
     } 
     return temp.remove(); 
     } 
    }); 

    $scope.processKey = function(e) { 
     var key; 
     key = e.which; 
     if (key === 9 || key === 13 || key === 188) { 
     $("div").find('.dh-tag-ctn .input-tag').css({ 
      "background-color": " #FCF8E3" 
     }); 
     e.preventDefault(); 
     return $scope.addTag(); 
     } 
     if (key === 8) { 
     $("div").find('.dh-tag-ctn .input-tag').css({ 
      "background-color": "rgba(255, 0, 0, 0.15)" 
     }); 
     $scope.deleteTag(); 
     } 
    }; 
    }, 
    //templateUrl: "tagInputTemplate.html", 
    template: "" + 
    "<div class='dh-tag-ctn'>" + 
    " <div class='input-tag' ng-hide={{display}} data-ng-repeat=\"tag in tagArray() track by $index\" ng-class='tag' >" + 
    "  <span>{{tag.name}}</span>" + 
    "  <div class='delete-tag' data-ng-click='deleteTag($index)'>&nbsp;&times;</div>" + 
    " </div>" + 
    " <input type='text' data-ng-style='{width: inputWidth}' ng-model='tagText' ng-keypress='processKey($event)' ng-keyup='processKey($event)' placeholder='{{placeholder}}' />" + 
    "</div>" + 
    "<br>" + 
    "<div ng-show={{display}} class='dh-tag-ctn-view'><div class='input-tag' data-ng-repeat=\"tag in tagArray() track by $index\" ng-class='tag'>{{tag.name}}" + 
    " <div class='delete-tag' data-ng-click='deleteTag($index)'>&times;<br></div>" + 
    "</div>" 
    }; 
    }); 
</script> 

は、あなただけのボタンを作成し、あなたのタグ値

<div ng-controller='FormCtrl'> 
    <h4>tagging directive using angularjs</h4> 
    <dh-tag autocomplete='users' list="tag" placeholder='add a tag' display="false"></dh-tag> 
    {{ tag }} 
</div> 

Plunker https://plnkr.co/edit/hCgdCN?p=preview

を表示できる文字列データを送信する

UploadToServer()
<input type="button" value="Send" ng-click="UploadToServer()" /> 

あなたFormCtrlで機能

App.controller('FormCtrl', function($scope, $http) { 
    $scope.myfunc = function() { 
    $scope.tag = {}; 
    $http({ 
     method: 'POST', 
     url: 'tag.json', 
     data: $scope.tag 
    }).then(function(response) {}); 
    return $scope.users = { 
     "name": "AngularJS", 
     "name": "Javascript", 
     "name": "Java", 
     "name": "Spring", 
     "name": "PHP", 
     "name": "Ruby" 
    }; 
    } 
    $scope.UploadToServer = function() { 
    //insert all logic to send $scope.tag to database 
    }; 
}); 
+0

の場合は解決策がjsonオブジェクトにバインドされていますが、削除機能に影響を与えるかどうかを確認してください。 – Deepanjan

+0

よく調べてください –

+0

ありがとうございました。また、これはng-keypressイベントで発生します。 – Deepanjan

関連する問題