首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何使用 HTML、CSS 和 Vanilla JavaScript 以及本地存储创建待办事项应用程序

每个任务将包含以下元素: 用于将任务标记为完成的单选按钮 用于显示任务的 span 元素 一个编辑按钮和一个删除按钮 使用 CSS 设计样式 我们将从主体样式开始,以确保所有元素水平居中: body {...示例任务如下所示: { id:1700000, name: "Name of task", completed:false } 添加新任务 好吧,首先向添加任务按钮添加单击事件侦听器。...使用 forEach 迭代每个按钮 对于每个按钮,我们使用最接近按钮的 li 元素this.closest("li)(其中 this 指的是单击的按钮)。...在这个函数中,我们想要执行与删除按钮相同的步骤:即: 获取所有编辑按钮 使用forEach()方法迭代并获取最接近的li元素 获取 data-id 属性 allTasks使用 id 在数组中查找任务...本地存储是一个允许您在浏览器中存储数据的对象。数据以键值对的字符串形式存储。即使关闭浏览器后,存储在浏览器中的数据仍然存在。只有清除缓存后,它才会被删除。

14110

浅析 JavaScript 中的事件委托

; 以上就是侦听单个元素(尤其是按钮)上事件的方式。 如果需要监听多个按钮上的事件呢?...按钮列表被迭代为 for (const button of buttons) ,并且每个按钮都被附加了一个新的侦听器。另外在列表中的按钮被添加或删除后,你必须还要手动删除或附加事件监听器。...有没有更好的方法? 幸运的是,如果我们使用“事件委托”模式的话,侦听多个元素上的事件只需要一个事件侦听器。 事件委托使用事件传播机制的细节。想要要了解事件委托的工作原理,应该先了解什么是事件传播。...那么事件传播是怎样帮助捕获多个按钮事件的呢? 该算法很简单:把事件侦听器附加到按钮的父级,并在单击按钮时捕获冒泡事件。这就是事件委托的工作方式。...3.事件委托 让我们用事件委托来捕获多个按钮上的点击: <!

2.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用 HTML、CSS、JavaScript 创建一个简单的井字游戏

    我们还将获取对播放器显示、重置按钮和播音员的引用。...在每个子数组中,我们将存储可以赢得比赛的三个位置的索引。所以这[0, 1, 2]将代表第一条水平线被玩家占据的情况。我们将使用这个数组来决定我们是否有赢家。...如果所有字段都相等,那么我们就有一个赢家,因此我们将 roundWon 设置为 true 并中断 for 循环,因为任何进一步的迭代都会浪费计算。...我们可以通过循环遍历图块数组并为每个图块添加一个事件侦听器来做到这一点。...(为了获得更好的性能,我们只能向容器添加一个事件侦听器并使用事件冒泡来捕获父级上的磁贴点击,但我认为对于初学者来说这更容易理解。)

    2K21

    Web 性能优化:缓存 React 事件来提高性能

    object1 的地址与 object2 的地址是不一样的。这就是为什么这两个变量的等式检查没有通过的原因。它们的键值对可能完全相同,但是内存中的地址不同,这才是会被比较的地方。...浅比较用于比较对象的每个键值对,而不是比较内存地址。深比较更进一步,如果键-值对中的任何值也是对象,那么也对这些键-值对进行比较。React 都不是:它只是检查引用是否相同。...Button 的click事件侦听器需要独立于 SomeComponent。...当多个处理程序由多个变量确定时,可能需要使用自己的聪明才智为每个处理程序生成唯一标识符,但是在遍历里面,没有比每个 JSX 对象生成的 key 更简单得了。...但点击 index 为 0 的按钮 pizza 的时候,它将会弹出 soda。这也是 React 建议不要使用数组的索引作为 key 的原因。 你的点赞是我持续分享好东西的动力,欢迎点赞!

    2.1K20

    JavaSwing_8.1:焦点事件及其监听器 - FocusEvent、FocusListener

    该事件被传递给每一个FocusListener或FocusAdapter注册,以接收使用组件的此类事件对象addFocusListener方法。...对处理焦点事件感兴趣的类 要么实现此接口(以及它包含的所有方法) 要么扩展抽象FocusAdapter类(仅覆盖感兴趣的方法) 然后,使用组件的addFocusListener方法向组件注册从该类创建的侦听器对象...使用扩展的类创建一个侦听器对象,然后使用组件的 addFocusListener 方法向组件注册该监听器。...例如,当焦点从按钮转到文本字段时,按钮会触发焦点丢失事件(文本字段为相反的组件),然后文本字段会触发焦点获取事件(带有按钮作为相反的组件)。失去焦点以及获得焦点的事件可能是暂时的。...该演示可以使用setFocusable(false)从焦点循环中真正删除该文本区域,但这将产生不幸的后果,使使用辅助技术的人员无法使用该组件。 再次按Tab键。焦点从列表移回到文本字段。

    4.7K10

    Vue 指令知多少

    .capture:添加事件侦听器时使用 capture 模式。 .self:只当事件是从侦听器绑定的元素本身触发时才触发回调。 .....passive:(2.3.0) 以{ passive: true }模式添加侦听器 说明: 绑定事件监听器。 用在普通元素上时,只能监听原生 DOM 事件。...用在自定义元素组件上时,也可以监听子组件触发的自定义事件。 从2.4.0开始,v-on同样支持不带参数绑定一个事件/监听器键值对的对象。注意当使用对象语法时,是不支持任何修饰器的。....camel: (2.1.0+) 将 kebab-case 特性名转换为 camelCase .sync:语法糖,会扩展成一个更新父组件绑定值的 v-on 侦听器 说明: 动态地绑定一个或多个特性...没有参数时,可以绑定到一个包含键值对的对象。注意此时 class 和 style 绑定不支持数组和对象。 示例: <!

    1.6K40

    分享近百道JavaScript 基础面试题,帮助你巩固JavaScript 基础知识

    你可以使用 for 循环、forEach()、map()、filter()、reduce() 和其他数组方法遍历数组。 13. 你如何处理 JavaScript 中的错误?...JavaScript 中localStorage 对象的作用是什么? localStorage 对象允许你在浏览器的存储中存储键值对,即使在浏览器关闭后仍然存在。 21....32.解释JavaScript中事件委托的概念。 事件委托是一种将单个事件侦听器附加到父元素以处理由其子元素触发的事件的技术。它有助于优化性能并减少内存消耗。 33....你可以使用 Array.isArray() 方法来检查变量是否为数组。 62.解释JavaScript中事件委托的概念。 事件委托是一种将事件侦听器附加到父元素并侦听在其子元素上发生的事件的技术。...解释 JavaScript 中事件处理的概念。 事件处理涉及通过将事件侦听器附加到元素并在这些事件发生时执行代码来响应用户与网页的交互。 81.

    34610

    List,Map 三种遍历方式:(总结理解)

    ⌨ ☀️相关笔记章节: java 1.8 stream使用总结(个人总结有一些经典文章的集合) 遍历 ArrayList和遍历 Map的几种方式 Java对象,Map,List,Set数组等相互转换大全...迭代器(Iterator)遍历: 迭代器是一种通用的遍历方式,适用于List和Map。 List遍历: 使用迭代器遍历List中的元素,对每个元素执行操作。...java复制代码list.forEach(element -> { // 操作element }); Map遍历: 使用Lambda表达式遍历Map中的键值对。...迭代器(Iterator)遍历: 迭代器是一种通用的遍历方式,适用于List和Map。 List遍历: 使用迭代器遍历List中的元素,对每个元素执行操作。...; * 然后是获得map的迭代器,用作遍历map中的每一个键值对; * iterator()是去获得这个集合的迭代器,保存在iter里面; */ Iterator<Map.Entry

    21800

    vue2.0知识点汇总

    .capture - 添加事件侦听器时使用 capture 模式。 .self - 只当事件是从侦听器绑定的元素本身触发时才触发回调。 .....passive - (2.3.0) 以 { passive: true } 模式添加侦听器 用法: 绑定事件监听器。事件类型由参数指定。...表达式可以是一个方法的名字或一个内联语句,如果没有修饰符也可以省略。 从 2.4.0 开始,v-on 同样支持不带参数绑定一个事件/监听器键值对的对象。注意当使用对象语法时,是不支持任何修饰器的。...用在普通元素上时,只能监听 原生 DOM 事件。用在自定义元素组件上时,也可以监听子组件触发的自定义事件。 在监听原生 DOM 事件时,方法以事件为唯一的参数。...options中的一个filters的属性(一个对象) 多个key就是不同的过滤器名,多个value就是与key对应的函数体 Vue.filter(名, fn) 如果名称相同以局部为主 app.vue

    6.6K70

    前端开发必备之Chrome开发者工具(上篇)

    Chrome 中的Web开发和调试工具,可用来对网站进行迭代、调试和分析 打开 Chrome 开发者工具的方式有: 在Chrome菜单中选择 更多工具 > 开发者工具 在页面元素上右键点击,选择 “检查...使用元素面板可以自由的操作DOM和CSS来迭代布局和设计页面 编辑样式 使用 Styles 窗格可以修改与元素关联的 CSS 样式 ?...启用 Ancestors 复选框时查看祖先实体事件侦听器,即除了当前选定节点的事件侦听器外,还会显示其祖先实体的事件侦听器 启用 Framework listeners 复选框时查看框架侦听器,DevTools...那我们可以点击下方的格式化按钮对代码进行格式化: ?...事件监听器断点 当想要暂停事件侦听器代码时,使用事件侦听器断点 设置事件监听器断点: 点击 Sources 选项卡。 展开 “Event Listener Breakpoints” 窗格。

    8.3K111

    Vue 2.X 文档阅读笔记一 (基础)

    ②.数组语法 也可以将一个数组传给v-bind:class以应用一个class列表;如果想根据条件来切换列表的class,可以使用三元表达式,当判断逻辑较复杂时可以在数组中使用对象语法。...a.用v-for通过数组元素迭代 v-for指令可以挨个渲染一组数组的所有迭代元素,使用的特殊语法是item in items,其中items是源数据数组,item是数组元素迭代别名。...该特殊语法也可以写作item of items,即以of替代in作为分隔符,这类似于ES6中的迭代器语法。...v-for还支持一个可选的第二个参数作为当前项的索引,(item, index) in items。 在v-for循环的每个迭代块中,仍然拥有对父作用域属性的完全访问权限。...特性的初始值,而是将vue实例的数据作为数据来源,将多个复选框的v-model绑定到同一个数组; v-model应用于单选按钮时,会忽略checked特性的初始值

    3.5K70

    【Vue原理解析】之异步与优化

    异步更新机制Vue使用异步更新机制来提高渲染性能。当数据发生变化时,Vue并不立即重新渲染整个组件树,而是将更新操作推入一个队列中,并在下一个事件循环中执行。...当点击按钮时,会手动修改DOM元素的内容,并通过调用$forceUpdate方法强制组件重新渲染。这样可以确保即使数据没有发生变化,也能强制刷新组件以更新视图。...当点击按钮时,会向items数组中添加一个新的项。通过使用this.$set方法,我们可以确保新添加的项是响应式的,并能够触发视图更新。...注意事项避免频繁地使用$forceUpdate方法,因为它会跳过Vue的优化机制,可能导致性能下降。当使用异步更新机制时,需要注意避免对异步更新的数据进行同步操作,以免引起意外的结果。...异步更新机制通过将多个数据变化合并为一个更新操作,提高了渲染性能。而优化技巧如列表渲染优化、计算属性和侦听器、合理使用keep-alive等,进一步提升了应用程序的性能和用户体验。

    23420

    百度前端必会手写面试题及答案

    这时候就需要使用虚拟列表了,虚拟列表和虚拟表格在日常项目使用还是很多的判断对象是否存在循环引用循环引用对象本来没有什么问题,但是序列化的时候就会发生问题,比如调用JSON.stringify()对该类对象进行序列化...) { let handler; // 从储存事件键值对的this....) { let handler; // 从储存事件键值对的this....使用 Promise.resolve().then 可以把任务加到微任务队列,防止立即执行迭代方法 * 3. 微任务处理过程中,产生的新的微任务,会在同一事件循环内,追加到微任务队列里 * 4....ES6对迭代器的实现JS原生的集合类型数据结构,只有Array(数组)和Object(对象);而ES6中,又新增了Map和Set。

    52850

    这 10 个技巧让你成为一个更好的 Vue 开发者

    通过这篇文章,向你们介绍十个很酷的窍门和技巧,以帮助大家成为更好的 Vue 开发者。...假设有一个按钮组件,并且在某些情况下想监听单击事件,而在其他情况下想监听双击事件。...例如,可以利用它在可以通过v-html指令传递的方法中使用标记。在函数组件中,可以将此方法作为渲染函数中的第一个参数访问。...使用 JSX 由于Vue CLI 3默认支持使用JSX,因此现在(如果愿意)我们可以使用JSX编写代码(例如,可以方便地编写函数组件)。...但是,我们可以在Vue组件中指定一个模型属性,以定义使用什么事件和值 image.png 总结 希望这些窍门和技巧对你有所帮助,如果你也知道哪些技巧,欢迎留言。

    1.2K30
    领券