一个利用HTML5 localStorage功能的todo应用(angularJs+Bootstrap)

今天在网上看到一个简单的todo应用,使用angularJs做前端数据绑定,利用localStorage来存储数据,觉得挺有意思的。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html ng-app="todoApp">
  <head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"/>
<script src="/js/angular.js" type="text/javascript"></script>
<script src="//netdna.bootstrapcdn.com/bootstrap/3.0.3/js/bootstrap.min.js" type="text/javascript"></script>
<link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.3/css/bootstrap.min.css" type="text/css"/>
<script type="text/javascript" src="/less/js/app.js"></script>
<style>
  .center-grey{
 background:#f2f2f2;
 margin-top:20;
  }
  .top-buffer {
  margin-top:20px;
  }
  button{
  display: block;
  width: 100%;
  }
</style>
<title>Angular Todo Note App</title>
  </head>
  <body>
<div class="container center-grey" ng-controller="TodoController">
  <div class="row top-buffer" >
<span class="col-md-3"></span>
<span class="col-md-5">
  <input class="form-control" type="text" ng-model="note" placeholder="Add a note here"/>
</span>
<span class="col-md-1">
  <button ng-click="createNote()" class="btn btn-success">Add</button>
</span>
<span class="col-md-3"></span>
  </div>
  <div class="row top-buffer" >
<span class="col-md-3"></span>
<span class="col-md-6">
  <ul class="list-group">
<li ng-repeat="note in notes track by $index" class="list-group-item">
  <span>{{note}}</span>
</li>
  </ul>
</span>
<span class="col-md-3"></span>
  </div>
</div>
  </body>
</html>

ng-app声明了使用todoApp作为model

ng-controller声明了TodoController作为控制器

ng-model="note" 对输入框input进行了数据绑定,绑定到了$scope.note

ng-click="createNote"对函数(对象)进行了绑定,绑定到了$scope.createNote = function(){...}

ng-repeat = "note in notes track by $index" 以及{{note}} 是不是看上去很眼熟,对了,就是angularJs的循环遍历的写法,列出所有的notes数组里的数据

下面就是todoApp的js寇丁,controller‘TodoController‘传入$scope和notesFactory服务,

object.keys遍历localStorage里所有的key-value键值对

var todoApp = angular.module(‘todoApp‘,[]);

todoApp.controller(‘TodoController‘,function($scope,notesFactory){
    $scope.notes = notesFactory.get();
    $scope.createNote = function(){
        notesFactory.put($scope.note);
        $scope.note=‘‘;
        $scope.notes = notesFactory.get();
    }
});

todoApp.factory(‘notesFactory‘,function(){
    return {
    put: function(note){
        localStorage.setItem(‘todo‘ + (Object.keys(localStorage).length + 1), note);
    },
    get: function(){
        var notes = [];
        var keys = Object.keys(localStorage);
        for(var i = 0; i < keys.length; i++){
            notes.push(localStorage.getItem(keys[i]));
        }
        return notes;
    }
    };
})

BTW,通过firefox的开发者工具可以查看修改删除当前页面的localStorage内容,具体方法请猛戳这里

最后想说的是,angularJS真是一个好东西啊

一个利用HTML5 localStorage功能的todo应用(angularJs+Bootstrap),布布扣,bubuko.com

时间: 2024-12-22 04:20:45

一个利用HTML5 localStorage功能的todo应用(angularJs+Bootstrap)的相关文章

利用HTML5定位功能,实现在百度地图上定位

利用HTML5定位功能,实现在百度地图上定位 代码如下: <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>HTML5定位</title>     <script type="text/javascript" src="http://lib.sinaapp

利用HTML5定位功能,实现在百度地图上定位(转)

原文:利用HTML5定位功能,实现在百度地图上定位 代码如下: 测试浏览器:ie11定位成功率100%,Safari定位成功率97%,(add by zhj :在手机上测试(用微信内置浏览器打开),无论使用WIFI还是移动4G联网, 定位精度都是蛮高的,误差在几十米内) <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>

Smarge——基于HTML5 localStorage的key-value缓存框架

缓存是任何一个Web程序都需要重视的内容.受到Redis的启发,我想到开发一个基于HTML5 localStorage的key-value缓存框架,做了一些尝试之后,便有了Smarge这样一个产物. 大家都知道,HTML5的localStorage没有超时的机制,也不能存储数组和对象等类型,更没有命令空间等思想. 这些问题,在Smarge中都得到了解决. 项目地址:https://git.oschina.net/jiusem/Smarge.git 说明:Smarge1.0.js是完整的源代码,以

利用html5的本地存储功能实现登录用户信息保存

在HTML5中,本地存储是一个window的属性,包括localStorage和sessionStorage,从名字应该可以很清楚的辨认二者的区别,前者是一直存在本地的,后者只是伴随着session,窗口一旦关闭就没了.二者用法完全相同,这里以localStorage为例. 用户名.密码保存,自动登录等,可以通过设置cookie实现,第一次登录网站后在本地计算机的中写入cookie,之后再次登录此网站查看cookie中现有的值,用cookie值进行网站登录即可.但是 cookie 不适合大量数据

利用html5的本地存储写的一个购物车

好久没有写博客园了,很多知识没有记录下来:可惜: 这几天在开发微信,也写了一个订餐平台的微网站,里面需要写一个购物车: 这里主要是把商品的部分信息以json格式保存在sessionstorage中,还有商店信息也是: 以json格式保存有什么好处呢,轻量级的传输,大概是这样吧!另外,如果我们把商品信息分开存储,就会导致有多条的sessionstorage项,那以后实现在两家商店同时购物的话,就不可能区分每家商店的商品了: 如果代码是自己写的,就有版权,这么说.对吧,是在软件工程师书上看到的: 不

利用html5实现类似微信的手机摇一摇功能

利用html5实现类似微信的手机摇一摇功能,并播放音乐. 1.  deviceOrientation:封装了方向传感器数据的事件,可以获取手机静止状态下的方向数据,例如手机所处角度.方位.朝向等. 2.  deviceMotion:封装了运动传感器数据的事件,可以获取手机运动状态下的运动加速度等数据. 不多说直接上代码, Javascript: [javascript] view plaincopy var SHAKE_THRESHOLD = 3000; var last_update = 0;

利用html5制作一个时钟动画

1 <canvas id="clock" width="500" height="500" style="background-color: yellow"></canvas> 1 var clock=document.getElementById("clock"); 2 var cxt=clock.getContext("2d"); 3 function dra

python之路-利用索引切片功能做一个简易的两个未知数的加法计算器,代码如下:

python之路-利用索引切片功能做一个简易的两个未知数的加法计算器,代码如下: #content = input('请输入内容:'),如用户输入:5 +9或 5 + 9 等,然后进行分割再进行计算. content = input('>>>').strip() #content 等于所输入的内容,strip:删除字符串左右两边的空格. index = content.find('+') ''' content内容中的两边的空格都删除了,但中间还有,现在我们只需要定位已知内容是加法,两边

HTML5 LocalStorage 本地存储(转)

原文:http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html HTML5 LocalStorage 本地存储 说到本地存储,这玩意真是历尽千辛万苦才走到HTML5这一步,之前的历史大概如下图所示: 最早的Cookies自然是大家都知道,问题主要就是太小,大概也就4KB的样子,而且IE6只支持每个域名20个cookies,太少了.优势就是大家都支持,而且支持得还蛮好.很早以前那些禁用cookies的用户也都慢慢的不存在了