AngularJS 待办事项 App

下面是一个完整的 AngularJS 示例 App ,实现一个简单的待办事项清单(To-Do List) ,你可以直接复制粘贴到 .html 文件中运行:


✅ 示例:AngularJS 待办事项 App

复制代码
<!DOCTYPE html>
<html ng-app="todoApp">
<head>
  <meta charset="UTF-8">
  <title>AngularJS ToDo App</title>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.8.2/angular.min.js"></script>
  <style>
    body { font-family: Arial; padding: 20px; }
    ul { list-style-type: none; padding: 0; }
    li { margin: 5px 0; }
    .completed { text-decoration: line-through; color: gray; }
  </style>
</head>
<body ng-controller="TodoController">

  <h1>我的待办事项</h1>

  <input type="text" ng-model="newTask" placeholder="添加新任务" />
  <button ng-click="addTask()">添加</button>

  <ul>
    <li ng-repeat="task in tasks">
      <input type="checkbox" ng-model="task.done"> 
      <span ng-class="{completed: task.done}">{{ task.text }}</span>
      <button ng-click="removeTask($index)">删除</button>
    </li>
  </ul>

  <p>剩余任务:{{ remaining() }}</p>

  <script>
    var app = angular.module('todoApp', []);
    app.controller('TodoController', function($scope) {
      $scope.tasks = [
        { text: '学习 AngularJS', done: false },
        { text: '做一个示例 App', done: true }
      ];

      $scope.addTask = function() {
        if ($scope.newTask) {
          $scope.tasks.push({ text: $scope.newTask, done: false });
          $scope.newTask = '';
        }
      };

      $scope.removeTask = function(index) {
        $scope.tasks.splice(index, 1);
      };

      $scope.remaining = function() {
        var count = 0;
        angular.forEach($scope.tasks, function(task) {
          if (!task.done) count++;
        });
        return count;
      };
    });
  </script>

</body>
</html>

🧠 你可以学到:

功能 AngularJS 语法
数据绑定 {``{ task.text }}
控制器 ng-controller="TodoController"
模型绑定 ng-model="newTask"
列表渲染 ng-repeat="task in tasks"
条件样式 ng-class="{completed: task.done}"
事件处理 ng-click="addTask()"

运行结果如下:

相关推荐
袁煦丞15 分钟前
AI直接出答案!Perplexica开源搜索引擎:cpolar内网穿透实验室第534个成功挑战
前端·程序员·远程工作
Hilaku17 分钟前
用“人话”讲明白10个最常用的正则表达式
前端·javascript·正则表达式
木叶丸26 分钟前
跨平台方案该如何选择?
android·前端·ios
LL.。29 分钟前
同步回调和异步回调
开发语言·前端·javascript
网络点点滴33 分钟前
Vue如何处理数据、v-HTML的使用及总结
前端·vue.js·html
运维咖啡吧35 分钟前
周一才上线的网站,单单今天已经超过1000访问了
前端·程序员·ai编程
世界哪有真情38 分钟前
用虚拟IP扩容端口池:解决高并发WebSocket端口耗尽问题
前端·后端·websocket
前端世界38 分钟前
打造一个可维护、可复用的前端权限控制方案(含完整Demo)
前端
LeQi44 分钟前
当!important成为代码毒瘤:你的项目是不是也中了招?
前端·css·程序员
玲小珑1 小时前
Next.js 教程系列(九)增量静态再生 (ISR):动态更新的静态内容
前端·next.js