<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <title>ToDoList—最简单的待办事项列表</title>
    <meta name="description" content="ToDoList无须注册即可使用,数据存储在用户浏览器的html5本地数据库里,是最简单最安全的待办事项列表应用!">
    <title>ToDoList</title>
    <style type="text/css">
        body {
            margin:0;
            padding:0;
            font-size:16px;
            background: #CDCDCD;
        }
        header {
            height:50px;
            background:#333;
            background:rgba(47,40,45,0.70);
        }
        section{
            margin:0 auto;
        }
        label{
            float:left;
            width:100px;
            line-height:50px;
            color:#DDD;
            font-size:24px;
            cursor:pointer;
            font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
        }
        header input{
            float:right;
            width:60%;
            height:24px;
            margin-top:12px;
            /*首行缩进*/
            text-indent:10px;
            border-radius:5px;
            /*向框添加一个或多个阴影。该属性是由逗号分隔的阴影列表,每个阴影由 2-4 个长度值、可选的颜色值以及可选的 inset 关键词来规定。省略长度的值是 0*/
            box-shadow: 0 1px 0 rgba(255,255,255,0.24), 0 1px 6px rgba(0,0,0,0.45) inset;
            border:none
        }
        input:focus{
            /*属性设置元素整个轮廓的宽度,只有当轮廓样式不是 none 时,这个宽度才会起作用*/
            outline-width:0
        }
        h2{
            position:relative;
        }
        span{
            position:absolute;
            top:2px;
            right:5px;
            display:inline-block;
            padding:0 5px;
            height:20px;
            border-radius:20px;
            background:#E6E6FA;
            line-height:22px;
            text-align:center;
            color:#666;
            font-size:14px;
        }
        ol,ul{
            padding:0;
            list-style:none;
        }
        li input{
            position:absolute;
            top:2px;
            left:10px;
            width:22px;
            height:22px;
            cursor:pointer;
        }
        p{
            margin: 0;
        }
        li p input{
            top:3px;
            left:40px;
            width:70%;
            height:20px;
            line-height:14px;
            text-indent:5px;
            font-size:14px;
        }
        li{
            height:32px;
            line-height:32px;
            background: #fff;
            position:relative;
            margin-bottom: 10px;
            padding:0 45px;
            border-radius:3px;
            border-left: 5px solid #629A9C;
            box-shadow: 0 1px 2px rgba(0,0,0,0.07);
        }
        ol li{
            cursor:move;
        }
        ul li{
            border-left: 5px solid #999;
            /*不透明度*/
            opacity: 0.5;
        }
        li a{
            position:absolute;
            top:2px;
            right:5px;
            display:inline-block;
            width:14px;
            height:12px;
            border-radius:14px;
            border:6px double #FFF;
            background:#CCC;
            line-height:14px;
            text-align:center;
            color:#FFF;
            font-weight:bold;
            font-size:14px;
            cursor:pointer;
        }
        footer{
            color:#666;
            font-size:14px;
            text-align:center;
        }
        footer a{
            color:#666;
            text-decoration:none;
            color:#999;
        }
        /*页面宽度等于620时候执行里面代码*/
        @media screen and (max-device-width: 620px) {
            section{width:96%;padding:0 2%;}
        }
        /*当浏览器尺寸大于620px时候的代码了*/
        @media screen and (min-width: 620px) {
            section{width:600px;padding:0 10px;}
        }
    </style>
</head>
<body>
<header>
    <section>
        <form action="javascript:postaction()" id="form">
            <label for="title">ToDoList</label>
            <!--autocomplete="off"规定禁用自动完成功能-->
            <input type="text" id="title" name="title" placeholder="添加ToDo" required="required" autocomplete="off">
        </form>
    </section>
</header>
<section>
    <h2 onclick="save()">正在进行 <span id="todocount">0</span></h2>
    <ol id="todolist" class="demo-box"></ol>
    <h2>已经完成 <span id="donecount">0</span></h2>
    <ul id="donelist"></ul>
</section>
<footer>
    Copyright © 2014 todolist.cn <a href="javascript:clear();">clear</a>
</footer>
<script type="text/javascript">
function clear(){
    // localStorage本地存储
    localStorage.clear();
    load();
}

function postaction(){
    var title = document.getElementById("title");
    if(title.value == "") {
        alert("内容不能为空");
    }else{
        var data=loadData();
        var todo={"title":title.value,"done":false};
        data.push(todo);
        saveData(data);
        var form=document.getElementById("form");
        form.reset();
        load();
    }
}

function loadData(){
    var collection=localStorage.getItem("todo");
    if(collection!=null){
        return JSON.parse(collection);
    }
    else return [];
}

function saveSort(){
    var todolist=document.getElementById("todolist");
    var donelist=document.getElementById("donelist");
    var ts=todolist.getElementsByTagName("p");
    var ds=donelist.getElementsByTagName("p");
    var data=[];
    for(i = 0;i < ts.length; i++){
        var todo={"title":ts[i].innerHTML,"done":false};
        // unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。
        data.unshift(todo);
    }
    for(i = 0;i < ds.length; i++){
        var todo={"title":ds[i].innerHTML,"done":true};
        data.unshift(todo);
    }
    saveData(data);
}

function saveData(data){
    // JSON.stringify()把对象的类型转换为字符串类型
    localStorage.setItem("todo",JSON.stringify(data));
}

function remove(i){
    var data=loadData();
    var todo=data.splice(i,1)[0];// 从i开始删除一个元素
    saveData(data);
    load();
}

function update(i,field,value){
    var data = loadData();
    var todo = data.splice(i,1)[0];
    todo[field] = value;
    data.splice(i,0,todo);
    saveData(data);
    load();
}

function edit(i)
{
    load();
    var p = document.getElementById("p-"+i);
    title = p.innerHTML;
    p.innerHTML="<input id='input-"+i+"' value='"+title+"' />";
    var input = document.getElementById("input-"+i);
    input.setSelectionRange(0,input.value.length); // 选中value内容
    input.focus();
    input.onblur =function(){
        if(input.value.length == 0){
            p.innerHTML = title;
            alert("内容不能为空");
        }
        else{
            update(i,"title",input.value);
        }
    };
}

function load(){
    var todolist=document.getElementById("todolist");
    var donelist=document.getElementById("donelist");
    var collection=localStorage.getItem("todo");
    if(collection!=null){
        var data=JSON.parse(collection);
        var todoCount=0;
        var doneCount=0;
        var todoString="";
        var doneString="";
        for (var i = data.length - 1; i >= 0; i--) {
            if(data[i].done){
                doneString+="<li draggable='true'><input type='checkbox' onchange='update("+i+",\"done\",false)' checked='checked' />"
                +"<p id='p-"+i+"' onclick='edit("+i+")'>"+data[i].title+"</p>"
                +"<a href='javascript:remove("+i+")'>-</a></li>";
                doneCount++;
            }
            else{
                todoString+="<li draggable='true'><input type='checkbox' onchange='update("+i+",\"done\",true)' />"
                +"<p id='p-"+i+"' onclick='edit("+i+")'>"+data[i].title+"</p>"
                +"<a href='javascript:remove("+i+")'>-</a></li>";
                todoCount++;
            }
        };
        todocount.innerHTML=todoCount;
        todolist.innerHTML=todoString;
        donecount.innerHTML=doneCount;
        donelist.innerHTML=doneString;
    }
    else{
        todocount.innerHTML=0;
        todolist.innerHTML="";
        donecount.innerHTML=0;
        donelist.innerHTML="";
    }

var lis=todolist.querySelectorAll('ol li'); // 返回li元素的集合
    [].forEach.call(lis, function(li) {
        li.addEventListener('dragstart', handleDragStart, false);
        li.addEventListener('dragover', handleDragOver, false);
        li.addEventListener('drop', handleDrop, false);

onmouseout =function(){
            saveSort();
        };
    });
}

window.onload=load;

window.addEventListener("storage",load,false);

var dragSrcEl = null;
function handleDragStart(e) {
    dragSrcEl = this;
    e.dataTransfer.effectAllowed = 'move';
    e.dataTransfer.setData('text/html', this.innerHTML);
}
function handleDragOver(e) {
    if (e.preventDefault) {
        e.preventDefault();
    }
    e.dataTransfer.dropEffect = 'move';
    return false;
}
function handleDrop(e) {
    if (e.stopPropagation) {
        e.stopPropagation();
    }
    if (dragSrcEl != this) {
        dragSrcEl.innerHTML = this.innerHTML;
        this.innerHTML = e.dataTransfer.getData('text/html');
    }
    return false;
}

</script>

</body>
</html>

todolist_高级写法的更多相关文章

  1. css自适应宽度高级写法:一行多列~~~某些列的宽度是固定值

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAxgAAACdCAIAAAC4iknFAAAgAElEQVR4nO2d3VsTV7uH51/wqhKotn

  2. Cocos2dx-Android 之Makefile通用高级写法

    不废话,直接贴.节约时间.须要改进的地方请各位指出.共同学习. LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := c ...

  3. c#高级写法

    Linq的参考资料:https://www.cnblogs.com/liqingwen/p/5801249.html 1.判断str字符串中的逗号个数 string str = "1,2,3 ...

  4. 2017.10.13 Java中引用类型变量的创建及使用&循环高级写法

    今日内容介绍 1.引用类型变量的创建及使用 2.流程控制语句之选择语句 3.流程控制语句之循环语句 4.循环高级 ###01创建引用类型变量公式     * A: 创建引用类型变量公式         ...

  5. nginx 二级目录高级写法

    nginx二级目录高级配置: location ~ .*\.(html)$ { expires 1m; error_page 404 = /test/index.html; access_log /d ...

  6. vue指令实现拖动的高级写法

    不熟悉vue自定义指令看这里: https://cn.vuejs.org/v2/guide/custom-directive.html vue指令实现拖动方法很方便也挺简单,但是网上大部分的教程代码, ...

  7. js高级写法

    名称 一般写法 优化 取整(不四舍五入) parseInt(a,10); //Before Math.floor(a); //Before a>>0; //Before ~~a; //Af ...

  8. Android.mk高级写法

    转:http://blog.csdn.net/langresser_king/article/details/8275291 原本只是想记录一些常用的使用技巧,但是越写越得意(>_<),忍 ...

  9. .net 高级写法总结

    1.处理HTTP非正常的请求参数: [1] 获取相应的流转为string [2] request 的只读属性设置为可编辑,类似form [3] 转换为json对象 [4] 重设只读属性 //判断请求类 ...

随机推荐

  1. [原][osgearth]FAQ

    参考:http://docs.osgearth.org/en/latest/faq.html Common Usage How do I place a 3D model on the map? Th ...

  2. HTML之页面镶嵌体验

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. Android-----购物车(包含侧滑删除,商品筛选,商品增加和减少,价格计算,店铺分类等)

    电商项目中常常有购物车这个功能,做个很多项目了,都有不同的界面,选了一个来讲一下. 主要包含了 店铺分类,侧滑删除,商品筛选,增加和减少,价格计算等功能. 看看效果图: 重要代码: private v ...

  4. hdu 6386 Age of Moyu (重边判断)

    本来用一个map判重边结果T了, 实际上可以直接给边上打标记即可 int n, m; struct _ {int to,w,vis;}; vector<_> g[N]; int dis[N ...

  5. sed:轻量级流编辑器

    一. sed命令 sed是一种几乎包括在所有UNIX平台(包括Linux)的轻量级流编辑器.sed主要是用来将数据进行选取.替换.删除.新增的命令 注意:vi命令只能修改文件,但不能修改命令的结果,如 ...

  6. python运行错误---TabError: Inconsistent use of tabs and spaces in indentation

    本文转载于:http://blog.csdn.net/sinat_36384705/article/details/71155379 首先这个错误的意思是:在缩进的时候,使用了错误的空格和tab 我使 ...

  7. CentOS 6.5安装和配置ngix

    一.安装配置ngix 这里用wget直接拉取并安装资源文件 首先安装必要的库(nginx 中gzip模块需要 zlib 库,rewrite模块需要 pcre 库,ssl 功能需要openssl库). ...

  8. IOS-快速集成检查更新

    一直以为Appstore有了检查版本是否更新的机制,我们在APP上做这个更新功能会被拒,但是也有看到一些APP也是做了这个更新功能的.因为在网上没有找到完全正确的方法能获取到iTunes里的数据的,于 ...

  9. 关于app

    刷新功能的话只需要在前端重新调用一下原来的方法即可

  10. android中自定义view构造函数ContentItemView(Context context, AttributeSet paramAttributeSet)的用处

    自己定义一个view <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:a ...