使用jQuery和本地存储构建待办事项列表

在所有人的日子里,我们还有很多事情要做,但是没有办法知道我们是否会完成所有这些事情。 在这些情况下,待办事项清单将非常有帮助。 有出色的移动应用程序,在线工具,甚至WordPress插件都可以执行此任务,但是您是否想过自己创建一个插件需要多长时间?

在本教程中,我们将创建一个基本的待办事项列表。 任务将分为三类之一-未决,进行中和已完成。 我们的应用程序将允许创建新任务,这些新任务默认情况下属于待处理类别。 使用拖放技术可以轻松地在类别之间移动任务。 当然,任务也可以删除。

先决条件

在该项目中使用以下库。

  • jQuery 1.10.2
  • jQuery UI 1.10.3
  • Bootstrap 2.2.2

创建标记和CSS

在通过JavaScript添加功能之前,让我们创建应用程序的基本外观。

<div class="task-list" id="pending">
  <h3>Pending</h3>
  <!-- Sample task added manually to check look -->
  <div class="todo-task">
    <div class="task-header">Sample Header</div>
    <div class="task-date">25/06/1992</div>
    <div class="task-description">Lorem Ipsum Dolor Sit Amet</div>
  </div>
</div>

<div class="task-list" id="inProgress">
  <h3>In Progress</h3>
</div>

<div class="task-list" id="completed">
  <h3>Completed</h3>
</div>

<div class="task-list">
  <h3>Add a task</h3>
  <form id="todo-form">
    <input type="text" placeholder="Title" />
    <textarea placeholder="Descrtipion"></textarea>
    <input type="text" placeholder="Due Date (dd/mm/yyyy)" />
    <input type="button" class="btn btn-primary" value="Add Task" />
  </form>

  <input type="button" class="btn btn-primary" value="Clear Data" />

  <div id="delete-div">Drag Here to Delete</div>
</div>

接下来,使用以下CSS向元素添加一些样式。

.task-list {
  width: 250px;
  float: left;
  margin: 0 5px;
  background-color: #e3e3e3;
  min-height: 240px;
  border-radius: 10px;
  padding-bottom: 15px;
}

.task-list input, .task-list textarea {
  width: 240px;
  margin: 1px 5px;
}

.task-list input {
  height: 30px;
}

.todo-task {
  border-radius: 5px;
  background-color: #fff;
  width: 230px;
  margin: 5px;
  padding: 5px;
}

.task-list input[type="button"] {
  width: 100px;
  margin: 5px;
}

.todo-task > .task-header {
  font-weight: bold;
}

.todo-task > .task-date {
  font-size: small;
  font-style: italic;
}

.todo-task > .task-description {
  font-size: smaller;
}

h3 {
  text-align: center;
}

#delete-div {
  background-color: #fff;
  border: 3px dotted #000;
  margin: 10px;
  height: 75px;
  line-height: 75px;
  text-align: center;
}

我们的静态待办页面应如下图所示。

Todo list demo

定义JavaScript常量

在整个教程中,我们将引用某些常量以避免硬编码值。 这些常数如下所示。

var defaults = {
  // CSS selectors and attributes that would be used by the JavaScript functions
  todoTask: "todo-task",
  todoHeader: "task-header",
  todoDate: "task-date",
  todoDescription: "task-description",
  taskId: "task-",
  formId: "todo-form",
  dataAttribute: "data",
  deleteDiv: "delete-div"
}, codes = {
  "1" : "#pending", // For pending tasks
  "2" : "#inProgress",
  "3" : "#completed"
};

创建任务

使用以下JavaScript函数创建任务。

// Add Task
var generateElement = function(params) {
  var parent = $(codes[params.code]),
      wrapper;

  if (!parent) {
    return;
  }

  wrapper = $("<div />", {
    "class" : defaults.todoTask,
    "id" : defaults.taskId + params.id,
    "data" : params.id
  }).appendTo(parent);

  $("<div />", {
    "class" : defaults.todoHeader,
    "text": params.title
  }).appendTo(wrapper);

  $("<div />", {
    "class" : defaults.todoDate,
    "text": params.date
  }).appendTo(wrapper);

  $("<div />", {
    "class" : defaults.todoDescription,
    "text": params.description
  }).appendTo(wrapper);
};

以下代码示例显示了如何生成单个任务。

generateElement({
  id: "123",
  code: "1",
  title: "My Uber Important Task",
  date: "5/2/2014",
  description: "I have to do a lot of steps to implement this task!"
});

删除任务

删除任务非常简单,可以使用以下功能来完成。

var removeElement = function(params) {
  $("#" + defaults.taskId + params.id).remove();
};

在本地存储中保存任务

我们创建的任务可以使用数据库,cookie或许多其他技术来存储。 但是,在此应用程序中,为简单起见,我们将使用HTML5的本地存储。 在JavaScript中,变量localStorage存储所有这些数据。 以下代码示例显示了如何从本地存储中检索待办事项列表数据。

var data = JSON.parse(localStorage.getItem("todoData"));

每个任务将存储在data变量中。 示例任务对象如下所示。

{
  id : id, // Unique ID; timestamp is used here
  code: "1", // Code identifying the category
  title: title, // Title of the task
  date: date, // Due date
  description: description // Description of the task
}

我们使用以下代码更新本地存储中保存的数据。

localStorage.setItem("todoData", JSON.stringify(data));

提交待办事项表格

提交待办事项表单后,将创建一个新任务并将其添加到本地存储中,并更新页面的内容。 以下功能实现了此功能。

var addItem = function() {
  var inputs = $("#" + defaults.formId + " :input"),
      errorMessage = "Title can not be empty",
      id, title, description, date, tempData;

  if (inputs.length !== 4) {
    return;
  }

  title = inputs[0].value;
  description = inputs[1].value;
  date = inputs[2].value;

  if (!title) {
    generateDialog(errorMessage);
    return;
  }

  id = new Date().getTime();

  tempData = {
    id : id,
    code: "1",
    title: title,
    date: date,
    description: description
  };

  // Saving element in local storage
  data[id] = tempData;
  localStorage.setItem("todoData", JSON.stringify(data));

  // Generate Todo Element
  generateElement(tempData);

  // Reset Form
  inputs[0].value = "";
  inputs[1].value = "";
  inputs[2].value = "";
};

实施拖放

jQuery UI提供拖放功能。 我们需要使每个任务可拖动,并使三个类别中的每一个都可拖放。 要删除任务,默认情况下我们需要隐藏删除区域,并在拖动项目时显示它。 因此,我们首先稍微修改generateElement()函数,以使待办事项列表项可拖动,然后在该项处于药物状态时使删除区域可见。

$("." + defaults.todoTask).draggable();

// Add Task
var generateElement = function(params) {
  wrapper.draggable({
    start: function() {
      $("#" + defaults.deleteDiv).show();
    },
    stop: function() {
      $("#" + defaults.deleteDiv).hide();
    }
  });
...
};

其次,我们需要将droppable()函数添加到每个类别中,因为应该在三个区域中的任何一个中放置元素。

// Adding drop function to each category of task
$.each(codes, function(index, value) {
  $(value).droppable({
    drop: function(event, ui) {
      var element = ui.helper,
          css_id = element.attr("id"),
          id = css_id.replace(options.taskId, ""),
          object = data[id];

      // Removing old element
      removeElement(object);

      // Changing object code
      object.code = index;

      // Generating new element
      generateElement(object);

      // Updating Local Storage
      data[id] = object;
      localStorage.setItem("todoData", JSON.stringify(data));

      // Hiding Delete Area
      $("#" + defaults.deleteDiv).hide();
    }
  });
});

第三,我们需要添加一些代码以将任务删除后将其删除。

// Adding drop function to delete div
$("#" + options.deleteDiv).droppable({
  drop: function(event, ui) {
    var element = ui.helper,
        css_id = element.attr("id"),
        id = css_id.replace(options.taskId, ""),
        object = data[id];

    // Removing old element
    removeElement(object);

    // Updating local storage
    delete data[id];
    localStorage.setItem("todoData", JSON.stringify(data));

    // Hiding Delete Area
    $("#" + defaults.deleteDiv).hide();
  }
});

结论

最终代码可在GitHub上获得 。 您还可以查看项目的现场演示

From: https://www.sitepoint.com/building-list-jquery-local-storage/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值