AngularJS는 많은 Google 제품에서 사용되어 온 뛰어난 프런트엔드 JS 프레임워크입니다. AngularJS에는 MVC, 모듈화, 자동화된 양방향 데이터 바인딩, 의미 태그, 종속성 주입 등 많은 기능이 있으며 그 중 가장 핵심은 다음과 같습니다. 이 글은 주로AngularJS의 사용법에 대한 몇 가지 관련 정보를 소개합니다. 필요한 친구들이 참고하면 도움이 될 것입니다.
AngularJS
Event 명령:
ng-click/dblclick ng-mousedown/up ng-mouseenter/leave ng-mousemove/over/out ng-keydown/up/press ng-focus/blur ng-submit
ng-click과 동일, 둘 다 이벤트를 dom에 바인딩합니다. 에 다음과 같이 ng-click과 같은 명령으로 $event를 전달합니다.
<button ng-click="clickFn($event)" class="btn btn-danger">aa</button>
양식 명령
ng-change
값이 변경될 때 유용합니다
값이 있음 일부 태그는 다음과 같이 할 수 있습니다. ng-model과 함께 사용할 수 있는 경우에만 사용하세요
ng-model과 함께 사용해야 합니다
데이터 검증 가능
ng-disabled 控制元素是否可用 ng-readonly ng-checked
체크박스 선택 여부 제어
전용 설정 이는 데이터를 통해 선택할지 여부만 제어할 수 있습니다
데이터를 통해 데이터를 제어하려면 ng-model을 설정하세요
disable과 readonly의 차이점Form 요소는 비활성화 또는 읽기 전용 속성을 설정하여 설정할 수 있습니다. 비활성화가 설정된 후에는 사용자가 사용할 수 없으며 양식은 필드를 제출하지 않습니다.
카운트다운 러쉬의 작은 경우
$interval 서비스는 더티 데이터 검사를 자동으로 수행할 수 있는 setInterval과 동일합니다. 클리어된 경우 할당한 다음 $interval.cancel(타이머)을 수행해야 합니다. ng-show는 true로 표시됩니다. 숨기려면 false
ng-hide를 숨기려면 true로 설정하세요. false 표시
var 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) })ng-bind 관련 ng- 바인드에 문제가 있습니다. 추가한 후에는 데이터 변수 뒤에 다른 것을 추가할 수 없습니다. 이 데이터만 이 레이블에 표시될 수 있으며 다른 것들은 작동하지 않습니다. 또 다른 문제는 라벨을 파싱할 수 없다는 것입니다. ng-bind-html
{{name}}---111
用ng-bind-template就好
ng-bind-template="{{name}}---111"
에 "ngSanitize"를 넣어야 합니다. 그런 다음 표시할 레이블을 변수에 걸어야 합니다. , 그런 다음 ng-bind-html
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>내부 요청이 ajax이므로 서버 환경에 있어야 합니다.
$scope.text='html/a.html'; ng-include='text', 노드가 내부적으로 동작하게 되고 성능이 좋지 않게 이렇게 구성하시면 되는데, 특정 순간에 뷰에 표시되는 데이터를 업데이트해도 괜찮습니다 AngularJS
ng-model-options='{updateOn:'blur'}'
객체 지향적 사고를 사용하여 컨트롤러를 작성할 수 있습니다
ng-controller
서비스에 대해 이야기해 보겠습니다. 서비스는 실제로 이미 많이 언급되었습니다. angularjs에서 서비스는 특정 함수를 통해 데이터와 상호 작용하는 데 사용됩니다. $ http service
<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"method는 전달 방법을 나타냅니다.
params 제출된 데이터는 $.ajax의 데이터와 동일합니다: {}
success Success callback
JSONP는 교차 문제를 해결하는 방법입니다. 도메인 문제 일반적인 방법
교차 도메인 문제: 브라우저에는 동일 출처 정책이 있기 때문에 서로 다른 도메인 간에 데이터를 교환할 때 교차 도메인 문제가 발생합니다.동일 출처 정책: 동일한 프로토콜, 동일한 도메인에서만 이름, 동일 포트 데이터 상호 작용은 JSONP 원칙: 스크립트 태그의 src 속성을 사용할 수 있습니다(콜백 함수를 사용하여 데이터를 수신함). 이는 동일 출처의 영향을 받지 않습니다. 정책 콜백 기능을 설정하여 다른 도메인에 데이터를 요청할 수 있습니다
데이터를 수신할 번호
JSONP는 프런트엔드와 백엔드를 결합한 크로스 도메인 방식입니다. 데이터를 콜백 함수에서 사용해야 한다면 백엔드는 데이터를 콜백 함수에 다시 넣어야 합니다JSONP属于AJAX吗?ajax是指通过使用xmlhttprequest对象进行异步数据交互的技术,jsonp是依靠scriptsrc属性来获取的,不属于ajax
JSONP有什么缺点,使用的时候需要注意什么?
不能post跨域处理,需要注意的是:每次请求应该动态的创建script标签和回调函数,数据获取完成后销毁。
如果method是jsonp的话,就可以用jsonp去跨域请求,但是注意要在url后写关于callback的值为JSON_CALLBACK
百度搜索小例子
这里引用的是 angular-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 }) } })
$location服务
console.log($location.absUrl())//输出绝对地址 console.log($location.host())//输出域名 console.log($location.port())//输出端口 console.log($location.protocol())//协议 $location.path("aaa")//在路由中控制切换页面 console.log($location.path()) // #/aaa
$log 服务
多种控制台输出模式
$log.info("info"); $log.warn("warn"); $log.error("error"); $log.log("log");
angularJs对服务供应商配置
例如
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就是一个自定义模块
相关推荐:
위 내용은 AngleJS의 일부 사용법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!