初学AngularJs 神奇的框架

前端之家收集整理的这篇文章主要介绍了初学AngularJs 神奇的框架前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

因为我个人不是经常用git 所以看到 NG的中文官网的教程感觉怪怪的,很不顺畅,所以其英文官网看了下一些例子。今晚只是刚开始接触NG,但我已经被它深深折服。


不习惯用git所以 没有去布置环境,暂时还没理清楚 环境配置之类的内容


直接导入 angular.js文件


先上我看的例子: 文件包括 angular.js todo.js todo.css

angular.module('todoApp',[])
  .controller('TodoListController',function() {
    var todoList = this;
    todoList.todos = [
      {text:'learn angular',done:true},{text:'build an angular app',done:false}];
 
 
    todoList.addTodo = function() {
      todoList.todos.push({text:todoList.todoText,done:false});
      todoList.todoText = '';
    };
 
    todoList.remaining = function() {
      var count = 0;
      angular.forEach(todoList.todos,function(todo) {
        count += todo.done ? 0 : 1;
      });
      return count;
    };
 
    todoList.archive = function() {
      var oldTodos = todoList.todos;
      todoList.todos = [];
      angular.forEach(oldTodos,function(todo) {
        if (!todo.done) todoList.todos.push(todo);
      });
    };
  });

<!doctype html>
<html ng-app="todoApp">
  <head>
   
    <script src="js/angular.js"></script>
    <script src="js/todo.js"></script> 
    
    <link rel="stylesheet" href="css/todo.css">
  </head>
  <body>
    <h2>Todo</h2>
    <div ng-controller="TodoListController as todoList">
      <span>{{todoList.remaining()}} of {{todoList.todos.length}} remaining</span>
      [ <a href="" ng-click="todoList.archive()">archive</a> ]
      <ul class="unstyled">
        <li ng-repeat="todo in todoList.todos">
          <label class="checkBox">
            <input type="checkBox" ng-model="todo.done">
            <span class="done-{{todo.done}}">{{todo.text}}</span>
          </label>
        </li>
      </ul>
      <form ng-submit="todoList.addTodo()">
        <input type="text" ng-model="todoList.todoText"  size="30"
               placeholder="add new todo here">
        <input class="btn-primary" type="submit" value="add">
      </form>
    </div>
  </body>
</html>


.done-true {
  text-decoration: line-through;
  color: grey;
}


首先在html 这个Template里面引入官方angular.js文件

另外自己创建了todo.js todo.css文件


html 标签中 引导了ng-app 其模块对应 todoApp 也就是 todo.js(这个control模块的引入必须再angular.js后面) ,该ng-app对应 todo.js里面的

angular.module('todoApp',[])模块
里面有一个控制器:
<pre name="code" class="javascript">controller('TodoListController',function() {
</pre><pre name="code" class="javascript">}
而这个控制器对应了 html 中的 ng-contorller,ng-contorller可以放置在任意标签内,但他的作用于则仅限于这个标签
 
</pre><pre name="code" class="javascript">这里主要的概念有 ng-app     ng-controller   ng-model  ng-repeat
ng-app标志着angular的作用域  ,ng-controller标志着controller的作用域  ng-model 对应着controller里面的model,事实上这样看起来M和C并没有分开,所以算不上是标准的MVC而更像是MVVM的模式,ng-repeat则用于对model的遍历


当V改变的时候,ng-model也随之改变,这也就是NG所说的双向数据绑定中的一个方向,当V内容改变,传给了MODEL,MODEL又传给了问候语{{}},这就是双向。

而当V改变了M,随着M的改变,V也跟着改变,这就是为什么说它是MVC的一种模式,但看起来又并不像的原因,因为MC没有分出来(或者说是我自己还没学深,毕竟我今天才看了个例子,只是我已经迫不及待想写下这篇博客了,NG真的很有魅力)


大概的重点就是这些了,我尝试着自己去写些小应用就睡觉了


稍微熟悉一下代码


<!--
	作者:250758092@qq.com
	时间:2016-09-08
	描述:
-->
	<!DOCTYPE HTML>
	<html ng-app="addList">
		
		<head>
			<title>AngularJS 学习之旅</title>
			<script type="text/javascript" src="js/angular.js">
				
			</script>
			<script type="text/javascript" src="js/todo.js">
				
			</script>
			<style type="text/css">
				ul li{
					list-style: none;
					width: 50px;
					height: 50px;
					background: red;
					float: left;
					margin-right: 5px;
				}
			</style>
		</head>
		<body ng-controller="addlist as list_c">
			<ul >
				
				<li ng-repeat="list_num in list_c.listArray track by $index ">{{list_num}}</li>
				
				
			</ul>
			
			<input ng-model="list_c.add_number" />
			<button ng-click="list_c.add_list()">增加LI</button>
		</body>
	</html>


ng-repeat中后面加上了 track by $index是因为如果array中push了重复的内容NG会报错,加上这一句就可以解决

另外如果要调用C里面的方法,所有的事件绑定都必须是NG封装好的,否则无效,比如 增加LI这个BUTTON,不能用onclick="list_C.add_list()" 而是用ng-click="list_c.add_list()"


angular.module('addList',[])
.controller("addlist",function(){
	
	var listController=this;
	listController.listArray=[];
	
	listController.add_list=function(){
		
		listController.listArray.push(listController.add_number);
			
	};
	
});

猜你在找的Angularjs相关文章