AngularJS实现todomvc

准备工作

参考http://todomvc.com/
todomvc-app-template下载:在相应的位置使用git复制项目git clone https://github.com/tastejs/todomvc-app-template.git
下载完后,在项目文件夹内npm install下载包
安装好后,可以进行预览。但是控制台有找不到文件的错误


learn.json用于展现官方的说明栏,使用npm uninstall todomvc-common --save来卸载
在index.html中删除末尾处<script src="node_modules/todomvc-common/base.js"></script>及head中的<link rel="stylesheet" href="node_modules/todomvc-common/base.css">

Angular 实现

模型准备
在项目文件夹中安装AngularJSnpm install angular --save
在index.html中引入AngularJS <script src="node_modules/angular/angular.js"></script>
在js/app.js中编写代码。默认传入的window对象用不到,改成angular对象。默认使用严格校验模式。
初始化,建立模块与控制器,并初始化文本列表的Model

(function (angular) {
    'use strict';
    //应用程序的主要的模块
    var myApp = angular.module('MyTodoMvc', []);
    // 注册一个主要的控制器
    myApp.controller('MainController', ['$scope', function($scope) {    
    // 文本框需要一个模型
    $scope.text = '';

    // 任务列表也需要一个
    // 每一个任务的结构 { id: 1, text: '学习', completed: true }
    $scope.todos = [{  id: 1,  text: '学习', completed: false}, 
                 { id: 2, text: '睡觉', completed: false  }, 
                 { id: 3, text: '打豆豆', completed: true }, ];
        }] 
    )
})(angular);

将模块与控制器引入到index.html

    <body ng-app="MyTodoMvc">
        <section class="todoapp" ng-controller="MainController">

将输入框绑定model<input class="new-todo" placeholder="What needs to be done?" ng-model="text" autofocus>
将li用ng-repeat来显示数据,将checkbox建立model,label用表达式来输出,edit时,model显示与label一致。当todo.completed为true时,ng-class为completed

                    <li ng-repeat="todo in todos" ng-class="{completed:todo.completed}">
                        <div class="view">
                            <input class="toggle" type="checkbox" ng-model="todo.completed">
                            <label>{{todo.text}}</label>
                            <button class="destroy"></button>
                        </div>
                        <input class="edit" ng-model="todo.text">
                    </li>

修改item总数<span class="todo-count"><strong>{{todos.length}}</strong> item left</span>
实现添加功能
首先在controller加上add函数,add功能todos数组中添加1项,ID用数组长度+1,$scope.todos.length + 1,text为输入的text模型的值,添加后,将text清空

    $scope.add = function() {
      $scope.todos.push({
        // 自动增长
        id: $scope.todos.length + 1,
        // 由于$scope.text是双向绑定的,add同时肯定可以同他拿到界面上的输入
        text: $scope.text,
        completed: false
      });
      // 添加后,清空文本框
      $scope.text = '';
    };

将input放到form中,回车后进行表单提交,通过ng-submit实现add函数

                <form ng-submit="add()">
                    <input class="new-todo" placeholder="What needs to be done?" ng-model="text" autofocus>
                </form>

实现删除功能
添加remove功能,遍历数组找到id,通过splice删除(从第i位起,删除1位)

    $scope.remove = function(id) {
      // 删除谁
      for (var i = 0; i < $scope.todos.length; i++) {
        if ($scope.todos[i].id === id) {
          $scope.todos.splice(i, 1);
          break;
        }
      }
    };

在htmel中添加ng-click指向remove<button class="destroy" ng-click="remove(todo.id)"></button>
由于删除后再添加,上面将id设成数组长度的方法会导致id重复,我们可以用随机数来解决,将add方法中id更新成id: Math.random(),,也可以添加个getid的方法,迭代获取

    function getId() {
      var id = Math.random(); // 1 2
      for (var i = 0; i < $scope.todos.length; i++) {
        if ($scope.todos[i].id === id) {
          id = getId();
          break;
        }
      }
      return id;
    }

清空功能
建立一个新数值,将没有completed的项放到这个数组中,然后将todos 数组指向这个新数组,就实现了clear completed功能。并实现检查是否有完成项的功能

    $scope.clear = function() {
      var result = [];
      for (var i = 0; i < $scope.todos.length; i++) {
        if (!$scope.todos[i].completed) {
          result.push($scope.todos[i]);
        }
      }
      $scope.todos = result;
    };
    // 是否有已经完成的
    $scope.existCompleted = function() {
      // 该函数一定要有返回值
      for (var i = 0; i < $scope.todos.length; i++) {
        if ($scope.todos[i].completed) {
          return true;
        }
      }
      return false;
    };

在button中引入这两个function <button class="clear-completed" ng-click="clear()" ng-show="existCompleted()">Clear completed</button>
双击编辑
当前currentEditingId初始值设为-1,即一个不可能存在的id,当编辑时,将其设为当前行的id,save方法停止编辑,将currentEditingId设为-1

    // 当前编辑哪个元素
    $scope.currentEditingId = -1;
    $scope.editing = function(id) {
      $scope.currentEditingId = id;
    };
    $scope.save = function() {
      $scope.currentEditingId = -1;
    };

再li的ng-class中加上editing:todo.id===currentEditingId
使得text响应双击事件<label ng-dblclick="editing(todo.id)">{{todo.text}}</label>
将input edit用form包起来实现回车触发save

<form ng-submit="save()">
    <input class="edit" ng-model="todo.text" ng-blur="save()">
</form>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,671评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,442评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,524评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,623评论 1 275
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,642评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,584评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,953评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,621评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,865评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,608评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,698评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,378评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,958评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,940评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,173评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,419评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,425评论 2 342

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,350评论 0 17
  • 这是vue官网的一个例子,挺适合作为vue应用的入门的。通过这个应用,我们能学到vue的【双向绑定】,【v-for...
    进击的前端阅读 10,025评论 3 33
  • 作者:王芃 wpcfan@gmail.com 第一节:初识Angular-CLI第二节:登录组件的构建第三节:建立...
    接灰的电子产品阅读 18,379评论 60 44
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,590评论 18 139
  • 早上起床的时候给孩子做的西红柿鸡蛋汤,下了一碗面条,可吃饭时他却说想吃方便面我说今早就吃这个,不吃就浪费了。明早再...
    笑看明天_30d5阅读 158评论 0 0