0
fellas!角度js:テキストエリアを検証できません
リンクをクリックするとテキスト領域を検証しようとしています。それは、フォームの中には入っていません。ユーザーがリンクをクリックすると、テキスト領域に入力されたコンテンツを投稿する必要があります(データベースに保存する)。
私はそれに対して妥当性を確認しました。残念ながら、それは機能していないし、私は空白の投稿をすることができます。私は空白のポスティングを防止しようとしています。私はフォームとコントローラをフィドルで再作成しました。リンクを提供します。しかしその前に、私のhtmlとjsコードを見てください。
HTML
<div ng-app="myApp" ng-controller="myMap">
<div class="post-textarea" ng-class="{ 'has-error': vm.currentPost.content.$dirty && vm.currentPost.content.$error.required }">
<textarea class="form-control" rows="3" ng-model="vm.currentPost.content" required></textarea>
<a ng-click="vm.addPost(vm.currentPost.content,vm.currentPost.$valid)">Clik to Post and validate</a>
</div>
</div>
JavaScript
angular.module('myApp', [])
.factory('myService', function($http) {
var baseUrl = 'api/';
return {
postCurrentPost: function(newPost) {
var dataPost = {
newPost: newPost
};
return $http({
method: 'post',
url: baseUrl + 'postCurrentPost',
data: dataPost,
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
});
}
};
})
.controller('myMap', function(myService, $http, $scope) {
var vm = this;
var userObject;
// Add a post
vm.addPost = function(newPost, isValid) {
if (isValid) {
var currentPost = vm.currentPost;
currentPost.content = ""; //clear post textarea
myService.postCurrentPost(newPost).success(function(data) {
vm.posts = data;
});
} else {
alert('Validation not working');
}
};
//Check validation
$scope.getError = function(error, name) {
if (angular.isDefined(error)) {
if (error.required && name == 'vm.currentPost.content') {
return "This field is required";
}
}
}
});
そして、ここFIDDLEです。
があることを試みた...しかし、それはまだ、エラーメッセージを示していません。 @sawbeanraz – Annabelle
私が追加したコードを試してください。フォームまたはng形式の指示文 – sawbeanraz
が必要です。コードが機能していません。私はそれをテストしました。 @sawbeanraz – Annabelle