当前位置: 首页 > wzjs >正文

网站开发+兼职项目ico众筹WordPress

网站开发+兼职项目,ico众筹WordPress,前端做的比较好的网站,我国网络营销现状分析需求:点击按钮后,将设定的一些信息插入到系统日历的日程安排中。 调研过程 先google了一段时间,了解该需求大概的实现方式。可以创建日历文件,在点击的时候下载该日历文件,看起来还比较复杂,并且由于不具…

需求:点击按钮后,将设定的一些信息插入到系统日历的日程安排中。

调研过程

  1. 先google了一段时间,了解该需求大概的实现方式。可以创建日历文件,在点击的时候下载该日历文件,看起来还比较复杂,并且由于不具备系统日历相关的知识,担心纯手写造成的bug难以解决,所以放弃了。
  2. 在npm上搜索了相关的插件,发现了add-to-calendar-button,看文档发现适配了很多平台上的日历,但是真正使用后发现无法满足需求,这个插件不支持配置日程中url。并且在第三方软件中也出现了打不开的bug,所以放弃了这个插件。但是在调试的过程中发现在android设备上或ios非safari的浏览器是无法直接插入系统日历的,而是下载日历ics文件自行导入。
  3. 既然知道了不同系统以及浏览器中的效果都不一样,那就只能想一个满足需求的同时还提高用户体验的办法了。我的项目是海外的,所以用safari和google浏览器的用户居多,并且也了解到需求方主要是要用ios日历提醒。
  4. 主动和产品沟通,ios用户保障在safari浏览器中插入系统日历,除开safari以外的用户(包含android/其它浏览器/第三方app内置浏览器)点击按钮后跳转google日历。
  5. 又去npm找生成ics文件的插件,发现了ics.js,配置项挺多的也满足需求。google日历官方给出的方式需要注册appKey,但是ai告诉我有另一种方式:跳转url并传参,但是google日历找不到参数文档,不过主要的信息也都可以写入。

源代码

封装公共方法,点击按钮后调用addCalendar

import moment from 'moment';
import { createEvent } from 'ics';
import { getBrowser } from '@/utils/common';/*** 添加谷歌日历* @param {Object} event - 日历事件对象
*/
const addGoogleCalendar = (event) => {const startDate = moment(event.start).format('YYYYMMDD[T]HHmmss');const endDate = moment(event.end).format('YYYYMMDD[T]HHmmss');const params = new URLSearchParams({action: 'TEMPLATE',text: event.name,dates: `${startDate}/${endDate}`,details: `${event.url}\n${event.description}`,ctz: event.timezone || 'Asia/Tokyo'});const googleUrl = `https://calendar.google.com/calendar/render?${params.toString()}`;console.log(decodeURIComponent(googleUrl));window.open(googleUrl, '_blank');
}/*** 为 Safari 用户创建并下载 ICS 文件* @param {Object} event - 日历事件对象
*/
const createICSEvent = (event) => {const filename = `${event.name}.ics`;const startMoment = moment.utc(event.start).local();const endMoment = moment.utc(event.end).local();const icsEvent = {start: [startMoment.year(),startMoment.month()+1,startMoment.date(),startMoment.hour(),startMoment.minute()],end: [endMoment.year(),endMoment.month()+1,endMoment.date(),endMoment.hour(),endMoment.minute()],title: event.name,description: `${event.url}\n${event.description}`,url: event.url,alarms: [{action: 'display',description: 'Reminder',trigger: { ...event.reminder, before: true }}]};createEvent(icsEvent, (error, value) => {if (error) {console.log(error);return;}if (!value) return;const file = new File([value], filename, { type: 'text/calendar' });const link = document.createElement('a');const url = URL.createObjectURL(file);link.href = url;link.download = filename;document.body.appendChild(link);link.click();document.body.removeChild(link);URL.revokeObjectURL(url);});
}/*** 添加日历* @param {Object} params - 日历参数* @param {string} params.name - 日历事件名称* @param {number} params.start - 日历事件开始时间* @param {number} params.end - 日历事件结束时间* @param {string} params.url - 日历事件 URL* @param {string} params.description - 日历事件描述(备注)
*/
export const addCalendar = (params) => {const finalParams = {...params,timezone: 'Asia/Tokyo',reminder: { hours: 1 }}const { isSafari } = getBrowser();if (isSafari) {createICSEvent(finalParams);} else {addGoogleCalendar(finalParams);}
}

相关文档

  1. stack overflow上关于google日历参数的回答
  2. ics.js
  3. add-to-calendar-button
http://www.dtcms.com/wzjs/612410.html

相关文章:

  • 英文网站制作公司哪家好html5开发手机网站教程
  • 巴中建设银行网站创新驱动发展战略方针
  • 做一个公司的门户网站多少钱微信小程序介绍
  • 注册网站验证码手机网站打开微信登录
  • 中国建筑建设通的网站电子商务等于做网站吗
  • 广西建设教育协会网站aso是什么意思
  • wordpress 媒体库图片网站优化设计
  • 有没有个人做网站的wordpress注册可见
  • 修改网站源码连接数据库怎么做查询建设规范的网站
  • 南通做百度网站的公司网站网站建设注册小程序
  • 重庆网站建设是什么做视频的网站有哪些
  • 江苏建设人才无纸化考核网站广告在线制作
  • 网站注册搜索引擎的目的是网站建设课程考核方案
  • 企业品牌网站建设价格台州自助建站在线咨询
  • 浙江省建设局网站wordpress nginx伪静态配置
  • 网站建设 amp 找VX cp5173企业网站建设多少家
  • 免费网站建设福州网站建设综合实训ppt
  • 国外优秀app设计网站有哪些百度推广怎么做效果好
  • 投票制作网站工具网站有哪些
  • 化工行业网站设计深圳品牌网站建设服务
  • .red域名做网站好不好桂林尚品网络做的网站好不好
  • 自定义导航网站 源码把自己的电脑做网站服务器
  • 怎么做网站差不多站长app推广之家
  • 泰安商城网站开发设计淘宝网站短链接怎么做
  • 企业在网站建设中需要做什么wordpress餐饮
  • 做爰 网站做响应式网站兼容哪几个尺寸
  • 制作好网站网站流量的主要来源有
  • 七米网站建设哪里建设网站
  • 泉州手机模板建站wordpress怎么装插件
  • 搭建织梦网站教程wordpress论坛查看用户密码