Query View 分享 | 自定义倒计时组件

花了大概 7 分钟让 Deepseek 帮忙写的一个 QueryView 的倒计时组件。

图片.png

效果如下:显示从今天到三月七日的倒计时。

图片.png

用法:在 Query View 自定义视图文件(见参考文档说明)中添加组件代码 countdown

图片.png

图片.png

const custom = { countdown: { use: (dv) => { return { render: (container, startDateStr, targetDateStr) => { // 创建容器 const countdownContainer = document.createElement('div'); Object.assign(countdownContainer.style, { maxWidth: '800px', margin: '5vh auto', padding: '2rem', //backgroundColor: '#f8f9fa', backgroundColor: 'var(--b3-theme-surface-light)', borderRadius: '15px', //boxShadow: '0 10px 30px rgba(0,0,0,0.1)' boxShadow: '0 10px 15px 3px var(--b3-theme-primary-lightest)' }); // 解析日期参数 // const parseDate = (str) => { // const isoRegex = /^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2})?$/; // return new Date(isoRegex.test(str) ? str : `${str}T00:00:00`); // }; // 计算时间差 const startDate = new Date(startDateStr); const targetDate = new Date(targetDateStr); const now = new Date(); const totalDuration = targetDate - startDate; const timeDiff = targetDate - now; // 时间单位计算 const days = Math.max(0, Math.floor(timeDiff / 864e5)); const hours = Math.max(0, Math.floor((timeDiff % 864e5) / 36e5)); const minutes = Math.max(0, Math.floor((timeDiff % 36e5) / 6e4)); const seconds = Math.max(0, Math.floor((timeDiff % 6e4) / 1e3)); // 百分比计算 const remainingPercent = totalDuration > 0 ? Math.max(0, Math.min(100, (timeDiff / totalDuration) * 100)).toFixed(1) : 0; // 创建进度条 const progressContainer = document.createElement('div'); Object.assign(progressContainer.style, { margin: '2rem 0', padding: '0 1rem' }); const progressBar = document.createElement('div'); Object.assign(progressBar.style, { height: '12px', backgroundColor: '#e9ecef', borderRadius: '6px', overflow: 'hidden' }); const progressFill = document.createElement('div'); Object.assign(progressFill.style, { height: '100%', background: 'linear-gradient(90deg, #4facfe 0%, #00f2fe 100%)', width: `${remainingPercent}%` }); const progressText = document.createElement('div'); Object.assign(progressText.style, { textAlign: 'center', marginTop: '0.5rem', color: '#6c757d', fontSize: '0.9em', fontWeight: '500' }); progressText.textContent = `${remainingPercent}% 剩余 (${startDate.toLocaleDateString()} - ${targetDate.toLocaleDateString()})`; // 构建进度条结构 progressBar.appendChild(progressFill); progressContainer.appendChild(progressBar); progressContainer.appendChild(progressText); // 创建时间轴 const timeline = document.createElement('div'); Object.assign(timeline.style, { display: 'flex', justifyContent: 'space-between', padding: '2rem 0' }); // 时间单位定义 const timeUnits = [ { name: 'days', value: days, color: '#3498db' }, { name: 'hours', value: hours.toString().padStart(2, '0'), color: '#2ecc71' }, { name: 'minutes', value: minutes.toString().padStart(2, '0'), color: '#f1c40f' }, { name: 'seconds', value: seconds.toString().padStart(2, '0'), color: '#e74c3c' } ]; // 创建时间单位块 timeUnits.forEach(unit => { const timeBlock = document.createElement('div'); Object.assign(timeBlock.style, { flex: '1', textAlign: 'center', padding: '1.5rem', //backgroundColor: 'white', backgroundColor: 'var(--b3-theme-background)', margin: '0 1rem', borderRadius: '12px', boxShadow: '0 4px 6px rgba(0,0,0,0.05)' }); const timeNumber = document.createElement('div'); Object.assign(timeNumber.style, { fontSize: '2.5em', fontWeight: '700', fontFamily: 'Arial, sans-serif', color: unit.color }); timeNumber.textContent = unit.value; const timeUnitText = document.createElement('span'); Object.assign(timeUnitText.style, { color: '#95a5a6', display: 'block', marginTop: '0.5rem', textTransform: 'uppercase', letterSpacing: '1px' }); timeUnitText.textContent = unit.name; timeBlock.appendChild(timeNumber); timeBlock.appendChild(timeUnitText); timeline.appendChild(timeBlock); }); // 组装完整结构 countdownContainer.appendChild(progressContainer); countdownContainer.appendChild(timeline); container.appendChild(countdownContainer); return countdownContainer; } }; }, alias: ['countdowntimer'] } } export default custom;

重载自定义组件

图片.png

最后在嵌入块中输入如下的代码

//!js const query = async () => { let dv = Query.DataView(protyle, item, top); dv.addcountdown('2025-02-26', '2025-03-07'); //实时倒计时, 但是不推荐 // let timer = setInterval(() => { // dv.repaint(); // }, 1000); // dv.addDisposer(() => { // clearInterval(timer); // }); dv.render(); } return query();

处于 keep simple 考虑,没有实时倒计时,不过你每次点击一下嵌入块的刷新按钮就会自动刷新当前的倒计时状态。

如果想要实时倒计时,把代码中的注释给去掉。

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25386 引用 • 104866 回帖
  • QueryView
    8 引用 • 46 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    267 引用 • 666 回帖
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖 • 1 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖 • 1 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    432 引用 • 1250 回帖 • 595 关注
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 4 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 615 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    116 引用 • 54 回帖 • 3 关注
  • Excel
    31 引用 • 28 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    133 引用 • 796 回帖 • 1 关注
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    37 引用 • 157 回帖 • 3 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 3 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 708 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    89 引用 • 122 回帖 • 618 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 654 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 556 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 77 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 788 关注
  • Visio
    1 引用 • 2 回帖 • 2 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 667 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    6 引用 • 141 回帖 • 1 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖