Cet article présente principalement quelques informations pertinentes sur l'utilisation d'angularJS. Les amis qui en ont besoin peuvent s'y référer
AngularJS
<.>Commande Event :
ng-click/dblclick ng-mousedown/up ng-mouseenter/leave ng-mousemove/over/out ng-keydown/up/press ng-focus/blur ng-submit
<button ng-click="clickFn($event)" class="btn btn-danger">aa</button>
Commande de formulaire
ng-change
Peut effectuer une vérification des données
ng-disabled 控制元素是否可用 ng-readonly ng-checked
La différence entre désactivé et lecture seule
Tous les éléments du formulaire peut être passé Définissez l'attribut désactivé ou en lecture seule pour le désactiver. Une fois désactivé, l'utilisateur ne peut pas l'utiliser et le formulaire ne soumettra pas le champ en lecture seule est uniquement désactivé par l'utilisateur, c'est-à-dire. l'utilisateur ne peut pas fonctionner, mais le formulaire est toujours Soumettracas d'achat urgent avec compte à rebours
Le service $interval est équivalent à setInterval, qui peut effectuer automatiquement une inspection des données salesclear Si tel est le cas, vous devez attribuer une valeur, puis $interval.cancel(timer)ng-show s'affiche comme vrai. false hideng-hide est vrai pour cacher. faux affichage ng-if est identique à ng-show, sauf que s'il n'est pas affiché, le nœud n'est pas dans le document domvar app = angular.module("myapp",[]) app.controller("myController",function ($scope,$interval) { $scope.num=1 $scope.canBuy = false $scope.time = 5 var timer = $interval(function () { $scope.time--; if($scope.time<=0){ $scope.canBuy=true $interval.cancel(timer) } },1000) })
Lié à ng-bind
Il y a un problème avec ng-bind Après l'avoir ajouté, vous ne pouvez pas ajouter d'autres éléments après la variable data. Cette balise ne peut afficher que cette donnée, mais. pas les autres. Par exemple,{{name}}---111 用ng-bind-template就好 ng-bind-template="{{name}}---111"
ng-bind-html="<h1>{{name}}---111</h1>"
$scope.text= "<h1>"+$scope.name+"---111</h1>" ng-bind-html=''text“ ng-non-bindable
<h3 ng-non-bindable>{{name}}</h3>
ng-include peut introduire un extrait de code HTML, qui également nécessite que des variables soient définies et des expressions peuvent également être écrites dans l'extrait de code
Notez que, comme la requête interne est ajax, elle doit être dans un environnement serveur$scope.text='html/a.html'; ng-include='text'
ng-model-options='{updateOn:'blur'}'
AngularJS
Vous pouvez utiliser la pensée orientée objet Contrôleur d'écritureng-controller
<p ng-controller="myController as myFun"> {{name}}<br> {{myFun.age}}<br> {{myFun.sex}} </p> myapp.controller("myController",["$scope",myFun]) function myFun($scope){ $scope.name='allen'; this.sex='male' } myFun.prototype.age="18"
Dans angulaireJS, les services sont utilisés pour interagir avec les données via certaines fonctions
Service $http
method représente la méthode de livraison get, post$http({ url:"http://datainfo.duapp.com/shopdata/getclass.php", method:"get", params:{} }).success(function(data){ $scope.dataList=data; }).error(function(error){ console.log(error) })
url data interface params Les données soumises sont équivalentes à $.ajax Les données dans : {}
success success callback
error error callback
Ici nous parlerons de la technologie JSONP
JSONP est un moyen courant de résoudre les problèmes inter-domainesProblèmes inter-domaines : étant donné que les navigateurs ont une politique de même origine, des problèmes inter-domaines se produiront lorsque des données sont échangées entre différents domaines
Stratégie originale : l'interaction des données ne peut être effectuée que sous le même protocole, même nom de domaine et même port
Principe de JSONP : des balises de script peuvent être utilisées (des fonctions de rappel seront utilisées pour recevoir data) L'attribut src n'est pas affecté par la politique de même origine et peut demander des données à différents domaines. Vous pouvez recevoir des données en définissant la fonction de rappel
numéro . JSONP est une méthode cross-domain qui combine front-end et back-end : parce que le front-end demande les données et doit les utiliser dans la fonction de rappel, le back-end doit mettre les données revenir dans la fonction de rappel
JSONP appartient-il à AJAX ? Ajax fait référence à la technologie d'interaction de données asynchrone en utilisant l'objet xmlhttprequest. JSONP est obtenu en s'appuyant sur l'attribut scriptsrc. Il n'appartient pas à ajax
Quels sont les inconvénients de JSONP ? à quand l'utiliser ?
ne peut pas publier de traitement inter-domaines. Il convient de noter que les balises de script et les fonctions de rappel doivent être créées dynamiquement pour chaque requête et détruites une fois l'acquisition des données terminée.
Si la méthode est jsonp, vous pouvez utiliser jsonp pour les requêtes inter-domaines, mais veillez à écrire la valeur du rappel après l'url sous la forme JSON_CALLBACK
Recherche Baidu petit exemple La référence ici est angulaire-sanitize.js
var app = angular.module("myapp",['ngSanitize']) app.controller("myController",function ($scope,$http) { $http({ url:"http://datainfo.duapp.com/shopdata/getclass.php", method:"post", params:{a:1} }).success(function (results) { $scope.dataList = results }).error(function (error) { console.log(error) }) }) app.controller("yourController",function ($scope,$http) { $scope.search = function () { $http({ url:"https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su", method:"jsonp", params:{ wd:$scope.wd, cb:'JSON_CALLBACK' } }).success(function (results) { $scope.dataList = results.s }) } })
console.log($location.absUrl())//输出绝对地址 console.log($location.host())//输出域名 console.log($location.port())//输出端口 console.log($location.protocol())//协议 $location.path("aaa")//在路由中控制切换页面 console.log($location.path()) // #/aaa
Modes de sortie de console multiples
Configuration du fournisseur de services AngularJs$log.info("info"); $log.warn("warn"); $log.error("error"); $log.log("log");
例如
myapp.config(["$interpolateProvider",function($interpolateProvider){ $interpolateProvider.startSymbol("!!"); $interpolateProvider.endSymbol("!!"); }])
angular就不认识{{}}了,开始变成!!!!
自定义服务 三种
1.factory
myapp.factory('serviceName',function(){ return .... })
可以return 字符串、数组、函数、对象(使用最多,最和逻辑)
引入方法和angualr自带的前面加$的服务完全一样,使用方法取决于return出来的是什么东西,自定义服务的服务名还是别加$了
eq:返回一个 两个数之间的随机数的服务
myapp.factory("myService",function(){ return { getRandom:function(a,b){ return Math.random()*(b-a)+a; } } })
自定义的服务可以依赖注入其他服务
myapp.factory('myHttpService',['$http',function($http){ return { $http({ url:...... }) } }])
eq:下一个自定义的http服务
myapp.factory("myHttpService",["$http",function($http){ return { http:function(url,sfn,efn){ $http({ url:url, method:"get" }).success(sfn).error(efn) } } }]) myHttpService.http("http://datainfo.duapp.com/shopdata/getclass.php",function(data){ console.log(data) },function(data){ console.log(data) })
2.provider
可以通过去自定义一个服务供应商去定义一个服务,写法有区别,服务功能性的东西需要嵌套一层返回
myapp. provider ('myHttpService',['$http',function($http){ return { $get:function(){ return:{//这里才是输出 } } }])
外面return出来的是这个服务的供应商,供应商的$get方法里返回的才是供我们使用的部分,可以通过更改供应商的部分参数来控制服务的功能,
eq:还是返回一个范围内的随机数,但是通过配置供应商的一个值来控制服务返回的是整数还是小数
myapp.provider("myService",function(){ return { isInt:true, $get:function(){ var that=this; return { getRandom:function(a,b){ var num=Math.random()*(b-a+1)+a; if(that.isInt){ return Math.floor(num); }else{ return(num) } } } } } }) myapp.config(["myServiceProvider",function(myServiceProvider){ myServiceProvider.isInt=false; }])
通过这种方法创建的服务是可以配置供应商的
3.service
通过这种方法创建出来的只能是对象
最简单的创建方式,自带返回,支持面向对象的写法
myapp.service("myService",function(){ this.getRandom=function(a,b){ return Math.random()*(b-a)+a; } }) myapp.service("myService",aaa) function aaa(){ this.getRandom=function(a,b){ return Math.random()*(b-a)+a; } }
多个控制器间数据的共享
实现多个控制器数据共享的方法有这样三种,
第一种比较简单,就是把数据放到父作用域上,就都可以访问了
第二种就是在控制器里通过$$prevSibling找到兄弟作用域,然后使用数据,需要注意的是,如果是初始数据类型的话就不能做数据双向绑定了
第三种是定义服务,把需要共享的数据做成服务,这样就都可以用了
<body> <p class="container"> <p ng-controller="firstController"> <input type="text" class="form-control" ng-model="name"> <input type="text" class="form-control" ng-model="data.name"> <input type="text" class="form-control" ng-model="Data.name"> <p> first-name:{{name}}<br> first-data-name:{{data.name}}<br> first-Data-name:{{Data.name}} </p> </p> <p ng-controller="secondController"> <p> second-name:{{name}}<br> second-data-name:{{data.name}}<br> second-Data-name:{{Data.name}} </p> </p> </p> </body> <script src="../Base/angular.min.js"></script> <script> var app=angular.module("myapp",[]); app.factory("Data",function () { return { name:'lily' } }) app.controller("firstController",function ($scope,Data) { $scope.name="allen"; $scope.data={ name:'tom' } $scope.Data=Data; }) app.controller("secondController",function ($scope,Data) { $scope.name=$scope.$$prevSibling.name; $scope.data=$scope.$$prevSibling.data; $scope.Data=Data; }) </script>
自定义模块
所有的模块都有服务,ng-app这个模块理由¥scope什么的服务,
咱们自己也可以写一个模块,然后里面可以去写服务
这样就可以把某些服务写在某个自定义的模块里,实现重复调用
例如把随机数的例子写在一个自定义的模块里
var myModule=angular.module("myModule",[]); myModule.service("myService",function(){ this.ran=function(a,b){ return Math.random()*(a+b)-a; } }) var myapp=angular.module("myapp",["myModule"]); myapp.controller("myController",["$scope","$log","myService",function($scope,$log,myService){ $log.log(myService.ran(5,10)) }])
其实像angualr.sanitize.js就是一个自定义模块
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!