欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼

 更新時(shí)間:2017年01月17日 08:19:57   作者:沛東  
本篇文章主要介紹了angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。

先上效果頁(yè)面:

其中幾個(gè)知識(shí)點(diǎn)

1、angularJs提供了幾個(gè)新的type類(lèi)型:

type="password"

type="email"

type="number"

type="url"

2、幾個(gè)參數(shù)含義

ng-required      //是否必填,true/false

ng-minlength     //最小長(zhǎng)度,數(shù)字

ng-maxlength     //最大長(zhǎng)度,數(shù)字

min              //最小數(shù)字,數(shù)字,僅在type="number"下

max              //最小數(shù)字,數(shù)字,僅在type="number"

3、幾個(gè)form控制變量,先來(lái)一段代碼

<form role="form" name="myform" >
 <div class="form-group" >
 <label class="col-sm-2">用戶(hù)名</label>
 <div class="col-sm-8">
   <input type="text" name="username" class="form-control" placeholder="請(qǐng)輸入用戶(hù)名"></div>
 </div>
</form>
formName.inputFieldName.$pristine   //字段是否未更改,對(duì)應(yīng)上面的html代碼即為 myform.username.$pristine

formName.inputFieldName.$dirty   //字段是否更改,對(duì)應(yīng)上面的html代碼即為 myform.username.$dirty

formName.inputFieldName.$valid   //字段有效,對(duì)應(yīng)上面的html代碼即為 myform.username.$valid

formName.inputFieldName.$invalid   //字段無(wú)效,對(duì)應(yīng)上面的html代碼即為 myform.username.$invalid

formName.inputFieldName.$error   //字段錯(cuò)誤信息,使用頻率比較高,對(duì)應(yīng)上面的html代碼即為 myform.username.$error

4、下面直接上代碼,首先是html代碼,使用了bootstrap.css樣式,在結(jié)尾引入了angular

<!DOCTYPE html>
<html>
<head>
 <title>form驗(yàn)證</title>
 <link rel="stylesheet" type="text/css" href="style/bootstrap.css">
</head>
<body ng-app="formModule">
<div style="margin-top: 60px;">
 <form role="form" name="myform" class="form-horizontal container" ng-controller="formctrl">
 <!-- 用戶(hù)名 -->
 <div class="form-group" ng-class="{'has-error':myform.username.$dirty && myform.username.$invalid}">
 <label class="col-sm-2">用戶(hù)名</label>
 <div class="col-sm-8">
   <input type="text" name="username" ng-minlength="5" ng-maxlength="10" ng-required="true" ng-model="data.username" class="form-control" placeholder="請(qǐng)輸入用戶(hù)名"></div>
 <div class="col-sm-2 text-danger" ng-show="myform.username.$error.minlength">用戶(hù)名必須大于5位</div>
 <div class="col-sm-2" ng-show="myform.username.$error.maxlength">用戶(hù)名必須小于于10位</div>
 </div>
<!-- 密碼 -->
<div class="form-group" ng-class="{'has-error':myform.password.$dirty&&myform.password.$invalid}">
 <label class="col-sm-2">密 碼</label>
 <div class="col-sm-8">
   <input type="password" name="password" ng-minlength="10" ng-required="true" ng-model="data.password" class="form-control" placeholder="請(qǐng)輸入密碼"></div>
 <div class="col-sm-2 text-danger" ng-show="myform.password.$error.minlength">密碼必須大于10位</div>
 </div>

 <!-- 確認(rèn)密碼 -->
 <div class="form-group" ng-class="{'has-error':myform.passwordconfirm.$dirty&&myform.passwordconfirm.$invalid}">
 <label class="col-sm-2">確認(rèn)密碼</label>
 <div class="col-sm-8">
   <input type="password" name="passwordconfirm" ng-required="true" ng-model="data.passwordconfirm" class="form-control" placeholder="請(qǐng)輸入確認(rèn)密碼"></div>
 <div class="col-sm-2 text-danger" ng-show="data.passwordconfirm!=data.password&&myform.password.$dirty&&myform.passwordconfirm.$dirty">兩次密碼不一致</div>
 </div>
 <!-- 郵箱 -->
 <div class="form-group" ng-class="{'has-error':myform.email.$dirty&&myform.email.$invalid}">
 <label class="col-sm-2">郵 箱</label>
 <div class="col-sm-8">
   <input type="email" name="email" ng-required="true" ng-model="data.email" class="form-control" placeholder="請(qǐng)輸入郵箱地址"></div>
 <div class="col-sm-2 text-danger" ng-show="myform.email.$error.email">請(qǐng)輸入正確郵箱地址</div>
 </div>
 <!-- 博客 -->
 <div class="form-group" ng-class="{'has-error':myform.age.$dirty&&myform.age.$invalid}">
 <label class="col-sm-2">年 齡</label>
 <div class="col-sm-8">
   <input type="number" name="age" ng-required="true" min="10" max="99" ng-model="data.age" class="form-control" placeholder="請(qǐng)輸入您的年齡"></div>
 <div class="col-sm-2 text-danger" ng-show="myform.age.$error.min&&myform.age$error.max">請(qǐng)輸入正確年齡</div>
 </div>
 <!-- 年齡 -->
 <div class="form-group" ng-class="{'has-error':myform.blog.$dirty&&myform.blog.$invalid}">
 <label class="col-sm-2">博 客</label>
 <div class="col-sm-8">
   <input type="url" name="blog" ng-required="true" ng-model="data.blog" class="form-control" placeholder="請(qǐng)輸入博客地址"></div>
 <div class="col-sm-2 text-danger" ng-show="myform.blog.$error.url">請(qǐng)輸入正確博客地址</div>
 </div>
 <!-- 性別 -->
 <div class="form-group">
 <label class="col-sm-2">性 別</label>
 <div class="col-sm-8">
  <label class="radio-inline">
   <input type="radio" value="1" ng-model="data.sex" name="sex"> 男</label>
 <label class="radio-inline">
   <input type="radio" value="2" ng-model="data.sex" name="sex"> 女</label>
 </div>
 </div>
 <!-- 愛(ài)好 -->
 <div class="form-group">
 <label class="col-sm-2">愛(ài) 好</label>
 <div class="col-sm-8">
 <label ng-repeat="hoppy in hoppies" class="checkbox-inline">
  <input type="checkbox" name="hoppy[]" ng-click="togglehoppy()" ng-model="hoppy.checked" >{{hoppy.name}}
 </label>
 </div>
 <div class="col-sm-2">{{data.Ahoppy.join('、')}}</div>
 </div>

 <!-- 地址 -->
 <div class="form-group">
  <label class="col-sm-2">地 址</label>
  <div class="col-sm-3">
   <select class="form-control" ng-model="data.provinec" ng-options="x.id as x.name for x in cities | cityfilter:0"></select>
  </div>
  <div class="col-sm-3">
   <select class="form-control" ng-show="data.provinec" ng-model="data.area" ng-options="x.id as x.name for x in cities | cityfilter:data.provinec"></select>
  </div>
  <div class="col-sm-3">
   <select class="form-control" ng-show="data.area" ng-model="data.city" ng-options="x.id as x.name for x in cities | cityfilter:data.area"></select>
  </div>
 </div>
 </form>
</div>

<script src="js/angular.js"></script>
<script src="js/app.js"></script>
</body>
</html>

 下面為js代碼(可能其中有些不妥之處,請(qǐng)指正,謝謝)

(function(window) {
 'use strict';
 var mymodule = angular.module('formModule', []);
 // 城市刪選器
 mymodule.filter('cityfilter',function(){
  return function(data,parent){
   var cityData=[];
   angular.forEach(data, function(item, key){
    if(item.parent==parent){
     cityData.push(item);
    }
   });
   return cityData;
  }
 });
 mymodule.controller('formctrl', ['$scope', function($scope) {
  // 設(shè)定初始狀態(tài)
  $scope.data={
   Ahoppy:[1,3]
  }
  // 愛(ài)好對(duì)象
  $scope.hoppies = [
  {id: 1,name: '玩游戲',checked: istrue(1)},
  {id: 2,name: '吃飯',checked: false}, 
  {id: 3,name: '睡覺(jué)',checked: false}, 
  {id: 4,name: '玩游戲',checked: true}
  ];
  // 城市
  $scope.cities=[
   {name:'河南',parent:0,id:1},
   {name:'鄭州',parent:1,id:2},
   {name:'鄭東新區(qū)',parent:2,id:3},
   {name:'金水區(qū)',parent:2,id:4},
   {name:'二七區(qū)',parent:2,id:5},
   {name:'信陽(yáng)',parent:1,id:6},
   {name:'商城',parent:6,id:7},
   {name:'羅山',parent:6,id:8},
   {name:'杭州',parent:0,id:9},
   {name:'西湖區(qū)',parent:9,id:10},
   {name:'余杭區(qū)',parent:9,id:11},
   {name:'蕭山區(qū)',parent:9,id:12},
   {name:'上城區(qū)',parent:9,id:13},
  ];
  
  // 判斷是否是選中狀態(tài)
  function istrue(id){
   for(var i=0;i<$scope.data.Ahoppy.length;i++){
    if($scope.data.Ahoppy[i]===id){
     return true;
    }
   }
   return false;
  };
  // 獲取選中的愛(ài)好

  $scope.togglehoppy = function() {
   $scope.data.Ahoppy = [];
   angular.forEach($scope.hoppies, function(item, key) {
    if (item.checked == true) {
     $scope.data.Ahoppy.push(item.id);
    }
   });
  }

 }])
})(window)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • angularJs使用ng-repeat遍歷后選中某一個(gè)的方法

    angularJs使用ng-repeat遍歷后選中某一個(gè)的方法

    今天小編就為大家分享一篇angularJs使用ng-repeat遍歷后選中某一個(gè)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Angular.js指令學(xué)習(xí)中一些重要屬性的用法教程

    Angular.js指令學(xué)習(xí)中一些重要屬性的用法教程

    這篇文章主要給大家介紹了關(guān)于Angular.js指令學(xué)習(xí)中一些重要屬性的用法教程,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • AnglarJs中的上拉加載實(shí)現(xiàn)代碼

    AnglarJs中的上拉加載實(shí)現(xiàn)代碼

    上拉加載,是目前手機(jī)網(wǎng)站加載數(shù)據(jù)的一種常用方式,本文主要講解AnglarJs集成,上拉加載功能。感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-02-02
  • Angular?服務(wù)器端渲染錯(cuò)誤消息localStorage?is?not?defined解決分析

    Angular?服務(wù)器端渲染錯(cuò)誤消息localStorage?is?not?defined解決分析

    這篇文章主要為大家介紹了Angular?服務(wù)器端渲染錯(cuò)誤消息localStorage?is?not?defined解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • angularjs 獲取默認(rèn)選中的單選按鈕的value方法

    angularjs 獲取默認(rèn)選中的單選按鈕的value方法

    下面小編就為大家分享一篇angularjs 獲取默認(rèn)選中的單選按鈕的value方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • AngularJS 實(shí)現(xiàn)彈性盒子布局的方法

    AngularJS 實(shí)現(xiàn)彈性盒子布局的方法

    本文給大家?guī)?lái)一段簡(jiǎn)短代碼實(shí)現(xiàn)angularjs彈性布局效果,非常實(shí)用,對(duì)angularjs彈出布局知識(shí)感興趣的朋友可以參考下
    2016-08-08
  • 利用Jasmine對(duì)Angular進(jìn)行單元測(cè)試的方法詳解

    利用Jasmine對(duì)Angular進(jìn)行單元測(cè)試的方法詳解

    單元測(cè)試是一種能夠幫助開(kāi)發(fā)者驗(yàn)證代碼中某一部分有效性的技術(shù)。下面這篇文章主要給大家介紹了關(guān)于利用Jasmine對(duì)Angular進(jìn)行單元測(cè)試的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-06-06
  • angularjs的單選框+ng-repeat的實(shí)現(xiàn)方法

    angularjs的單選框+ng-repeat的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇angularjs的單選框+ng-repeat的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • AngularJS基礎(chǔ) ng-selected 指令簡(jiǎn)單示例

    AngularJS基礎(chǔ) ng-selected 指令簡(jiǎn)單示例

    本文主要介紹AngularJS ng-selected 指令,這里對(duì)ng-selected 指令的基礎(chǔ)資料做了詳細(xì)介紹,并附有示例代碼,有需要的小伙伴可以參考下
    2016-08-08
  • Angularjs實(shí)現(xiàn)mvvm式的選項(xiàng)卡示例代碼

    Angularjs實(shí)現(xiàn)mvvm式的選項(xiàng)卡示例代碼

    每位Web開(kāi)發(fā)者應(yīng)該都知道,選項(xiàng)卡是現(xiàn)代web網(wǎng)頁(yè)中最常用的效果之一,所以本文重點(diǎn)是用angularjs這個(gè)非常火mvvm框架,實(shí)現(xiàn)選項(xiàng)卡效果。有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2016-09-09

最新評(píng)論