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

网站搜索怎么做phpwordpress lazy load

网站搜索怎么做php,wordpress lazy load,台州网站搜索优化,wordpress 客户端源码分析基于VUE2转盘组件的开发 文章目录 基于VUE2转盘组件的开发前言一、开发步骤1.组件布局2.布局样式3.数据准备 二、最后效果总结 前言 因为之前的转盘功能是图片做的#xff0c;每次活动更新都要重做UI和前端#xff0c;为了解决这一问题进行动态配置转盘组件开发#xff0c;…基于VUE2转盘组件的开发 文章目录 基于VUE2转盘组件的开发前言一、开发步骤1.组件布局2.布局样式3.数据准备 二、最后效果总结 前言 因为之前的转盘功能是图片做的每次活动更新都要重做UI和前端为了解决这一问题进行动态配置转盘组件开发可以减少一些UI和前端的工作量。 一、开发步骤 1.组件布局 van-row classcontainer!-- turntableBox 为整个转盘容器为正方形大小由里面元素决定 --van-col span24 classturntableBox!-- turntableMain 为转盘底座比里面的内容大显示为效果图灰色外圈但不是空心圆 --div classturntableMain :styleheight:${window.innerWidth * 0.8}px;width:${window.innerWidth * 0.8}px;!-- turntable 为转动区域作用是为了不让外圈一起转动 --div refturntable classturntable:styleheight:${window.innerWidth * 0.8}px;width:${window.innerWidth * 0.8}px;!-- Canvas 转盘饼图背景具体划分多少块由奖项决定 --Canvas /!-- prizeBox 奖项高为饼图的半径宽为饼图半径里面有多少块就多少分之一 --div classprizeBoxdiv classprizeItem :stylewidth:${perPrize.width}px;height:${perPrize.height}px;transform:translateX(-50%) rotate(-${(perPrize.degree * (index 1)) - (perPrize.degree / 2)}deg);left:calc(50%)v-for(item, index) in activeInfo.prizeList :keyindexp classtitle{{ item.name }}/pp classdescribe{{ item.describe }}/pimg :srcitem.img stylewidth: 38%; //div/div/div!-- 启动按钮 --van-image classgo fitcover width42px :srcgoPointer clickgo //div/van-col!-- 结果展示列表 --van-col span24div idresult/div/van-col/van-row2.布局样式 .turntableBox {margin-top: 10%;.turntableMain {margin: 0 auto;position: relative;border: 10px solid #E5E5E5;border-radius: 100%;}.turntable {transition: all 4s;margin: 0 auto;}.go {position: absolute;top: calc(50% - 31px);left: calc(50% - 21px);}.prizeBox {position: absolute;width: 80%;top: 0;left: calc(50% - 40%);.prizeItem {text-align: center;position: absolute;top: 0;overflow: hidden;text-align: center;transform-origin: center bottom;transform: translateX(-50%);color: #2c3e50;p {margin: 0;padding: 0;}.title {font-size: 18px;margin-top: 12px;}.describe {font-size: 14px;line-height: 28px;white-space: break-spaces;}img {margin-top: 6px;}}} }3.数据准备 data 代码如下包含页面功能所需要的变量 data() {return {window,/** 活动设置 */activeInfo: {/** 中奖概率 */probabilities: {一等奖: 10,二等奖: 10,三等奖: 10,四等奖: 10,},/** 奖品信息 */prizeList: [{name: 一等奖,describe: 一等奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},{name: 未中奖,describe: 未中奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},{name: 二等奖,describe: 二等奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},{name: 未中奖,describe: 未中奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},{name: 三等奖,describe: 三等奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},{name: 四等奖,describe: 四等奖,img: https://img01.yzcdn.cn/vant/cat.jpeg},]},/** 是否正在执行动画 */isGo: false,/** 执行动画的对象 */oTurntable: ,/** 即将旋转的度数 */randomDeg: 0,/** 上一次旋转的度数 */lastDeg: 0,/** 抽奖次数 */goTimes: 3,/** 奖品图片 */perPrize: {degree: null,width: null,height: null}}} created 代码如下主要处理角度、宽、高 created() {const params getAllParams();if (params) {this.params params;};/** 奖品 */const angle (360 / this.activeInfo.prizeList.length) / 2; // 对角角度const ratio Number(Math.sin(angle * (Math.PI * 2 / 360)).toFixed(2)); // 与半径的比率this.perPrize {degree: (360 / this.activeInfo.prizeList.length),width: Math.floor((window.innerWidth * ratio)) / 2,/** 高度是直径的一半 */height: window.innerWidth * 0.8 / 2}},mounted 代码如下获取转盘区域DOM元素方便后面操作 mounted() {this.oTurntable this.$refs.turntable;},methods 代码如下主要操作方法 /** 点击抽奖 */go() {/** 正在抽奖未结束继续点击无效 */if (!this.isGo this.goTimes 0) {/** 获取中奖结果再根据结果去转动转盘 */const result this.generatePrize();/** * 获取奖项下标* 奖项名字可能会重复所以需要找到奖项的所有下标保存到数组里* 根据下标数组随机生成一个数字来决定选择哪个下标成为最终结果的下标* */const resultIndexArray this.activeInfo.prizeList.reduce((acc, item, index) {if (item.name result) {acc.push(index);}return acc;}, []);const randomResultIndex Math.floor(Math.random() * resultIndexArray.length);const index resultIndexArray[randomResultIndex];/** 奖项总和数量 */const length this.activeInfo.prizeList.length;/** 调用旋转方法 */this.ratating((360 / length * index) (360 / length / 2), result);}else if (!this.isGo this.goTimes 0) {this.$toast({message: 抱歉您的抽奖次数用完了,duration: 3000,});}else {this.$toast(请勿重复点击)return}},/** 获取抽奖结果 */generatePrize() {/** 生成一个 0 到 99 之间的随机数 */const randomNum Math.floor(Math.random() * 100);let cumulativeProbability 0;/** 如果概率落在奖项范围内 */for (const prize in this.activeInfo.probabilities) {cumulativeProbability this.activeInfo.probabilities[prize];if (randomNum cumulativeProbability) {/** 返回中奖内容 */return prize;}}// 默认返回未中奖return 未中奖;},/** 该方法能产生[n,m]之间随机数,决定转盘转多少圈 */getRandom(n, m) {let result Math.floor(Math.floor(Math.random() * (m - n 1) n))return result;},/** 旋转 */ratating(deg, text) {this.goTimes--;this.isGo true;/** 旋转圈数 */let turnNumber this.getRandom(3, 6);/** 记录这次要旋转的度数(传来的度数圈数) */this.randomDeg deg 360 * turnNumber;/*上次指针离初始状态的度数 上次的度数 这次要旋转的度数(这样的目的是为了每次旋转都从原点开始保证数据准确)*/let realDeg (360 - this.lastDeg % 360) this.lastDeg this.randomDeg;/** 为对象添加执行动画 */this.oTurntable.style.transform rotate(${realDeg}deg);setTimeout(() {this.isGo false;var list document.getElementById(result);list.innerHTML /未中奖/.test(text) ? p很遗憾您${text}/p : p恭喜您获得${text}/p;/** 把这次度数存储起来方便下一次获取 */this.lastDeg realDeg;}, 4000);}canvas 组件代码如下主要使用canvas标签根据奖项长度进行角度划分绘画 templatecanvas classcanvas idcanvasImg :stylewidth:${perimeter}px;height: ${perimeter}px;您的浏览器不支持canvas/canvas /templatescriptexport default {name: Canvas,components: {},data() {return {/** 直径 */perimeter: 320,}},created() {},mounted() {this.perimeter window.innerWidth * 0.8;this.drawPie();},methods: {/** 画饼图 */drawPie() {const PI Math.PI;/** 获取画布并获取2d上下文对象 */const canvas document.getElementById(canvasImg);const ctx canvas.getContext(2d);/** 假设周长为500 */const perimeter this.perimeter;/** 半径 */const radius perimeter * 0.5;/** 总奖品数需要根据实际数据长度从父组件传入 */const prizeTotal 6;/** 每个扇形的角度360度 / 总奖品数 */const degree 360 / prizeTotal;/** 画布宽高 */canvas.width perimeter;canvas.height perimeter;/** 根据奖品数把圆形分成等份的扇形 */for (let i 0; i prizeTotal; i) {/** 奇偶颜色 */const color i % 2 0 ? #F8D383 : #F8E2BC;/** 开始一条新路径 */ctx.beginPath();/** 设置路径起点 */ctx.moveTo(radius, radius);/** 填充颜色 */ ctx.fillStyle color;/** 绘制扇形 圆心坐标圆心坐标半径扇形起始角度扇形终止角度 */ctx.arc(radius, radius, radius, (270 - degree (degree * i)) * PI / 180, (270 - degree degree (degree * i)) * PI / 180);/** 自动绘制一条当前点到起点的直线形成一个封闭图形省却使用一次moveTo方法。 */ctx.closePath();/** 闭合路径 */ctx.fill();}}}, } /scriptstyle langless/style 二、最后效果 总结 本文仅仅简单记录了转盘组件的基本实现仅供学习参考。
文章转载自:
http://www.morning.lqlhw.cn.gov.cn.lqlhw.cn
http://www.morning.xnpml.cn.gov.cn.xnpml.cn
http://www.morning.fgrcd.cn.gov.cn.fgrcd.cn
http://www.morning.yrmpz.cn.gov.cn.yrmpz.cn
http://www.morning.gjws.cn.gov.cn.gjws.cn
http://www.morning.wtsr.cn.gov.cn.wtsr.cn
http://www.morning.fksrg.cn.gov.cn.fksrg.cn
http://www.morning.xpmhs.cn.gov.cn.xpmhs.cn
http://www.morning.pdkht.cn.gov.cn.pdkht.cn
http://www.morning.bhrbr.cn.gov.cn.bhrbr.cn
http://www.morning.jrksk.cn.gov.cn.jrksk.cn
http://www.morning.lbfgq.cn.gov.cn.lbfgq.cn
http://www.morning.dkqyg.cn.gov.cn.dkqyg.cn
http://www.morning.gtqx.cn.gov.cn.gtqx.cn
http://www.morning.hnkkm.cn.gov.cn.hnkkm.cn
http://www.morning.jppdk.cn.gov.cn.jppdk.cn
http://www.morning.dmcqy.cn.gov.cn.dmcqy.cn
http://www.morning.gmyhq.cn.gov.cn.gmyhq.cn
http://www.morning.alive-8.com.gov.cn.alive-8.com
http://www.morning.rqqmd.cn.gov.cn.rqqmd.cn
http://www.morning.kmqms.cn.gov.cn.kmqms.cn
http://www.morning.lfqtp.cn.gov.cn.lfqtp.cn
http://www.morning.zlxkp.cn.gov.cn.zlxkp.cn
http://www.morning.sjwzz.cn.gov.cn.sjwzz.cn
http://www.morning.qkcyk.cn.gov.cn.qkcyk.cn
http://www.morning.wcczg.cn.gov.cn.wcczg.cn
http://www.morning.mmhaoma.com.gov.cn.mmhaoma.com
http://www.morning.yrdt.cn.gov.cn.yrdt.cn
http://www.morning.brlgf.cn.gov.cn.brlgf.cn
http://www.morning.burpgr.cn.gov.cn.burpgr.cn
http://www.morning.jhgxh.cn.gov.cn.jhgxh.cn
http://www.morning.mszwg.cn.gov.cn.mszwg.cn
http://www.morning.sfmqm.cn.gov.cn.sfmqm.cn
http://www.morning.fqsxf.cn.gov.cn.fqsxf.cn
http://www.morning.qtkfp.cn.gov.cn.qtkfp.cn
http://www.morning.bktzr.cn.gov.cn.bktzr.cn
http://www.morning.knqck.cn.gov.cn.knqck.cn
http://www.morning.huarma.com.gov.cn.huarma.com
http://www.morning.cnfjs.cn.gov.cn.cnfjs.cn
http://www.morning.lssfd.cn.gov.cn.lssfd.cn
http://www.morning.kzrg.cn.gov.cn.kzrg.cn
http://www.morning.xkyqq.cn.gov.cn.xkyqq.cn
http://www.morning.krnzm.cn.gov.cn.krnzm.cn
http://www.morning.mtdfn.cn.gov.cn.mtdfn.cn
http://www.morning.qyfrd.cn.gov.cn.qyfrd.cn
http://www.morning.mllmm.cn.gov.cn.mllmm.cn
http://www.morning.xlclj.cn.gov.cn.xlclj.cn
http://www.morning.fslxc.cn.gov.cn.fslxc.cn
http://www.morning.qpqwd.cn.gov.cn.qpqwd.cn
http://www.morning.dxpqd.cn.gov.cn.dxpqd.cn
http://www.morning.xrpjr.cn.gov.cn.xrpjr.cn
http://www.morning.rzmkl.cn.gov.cn.rzmkl.cn
http://www.morning.glncb.cn.gov.cn.glncb.cn
http://www.morning.yxzfl.cn.gov.cn.yxzfl.cn
http://www.morning.jrqbr.cn.gov.cn.jrqbr.cn
http://www.morning.plkrl.cn.gov.cn.plkrl.cn
http://www.morning.rrqbm.cn.gov.cn.rrqbm.cn
http://www.morning.gmmxh.cn.gov.cn.gmmxh.cn
http://www.morning.pplxd.cn.gov.cn.pplxd.cn
http://www.morning.qxlhj.cn.gov.cn.qxlhj.cn
http://www.morning.btypn.cn.gov.cn.btypn.cn
http://www.morning.rswtz.cn.gov.cn.rswtz.cn
http://www.morning.c-ae.cn.gov.cn.c-ae.cn
http://www.morning.xphls.cn.gov.cn.xphls.cn
http://www.morning.rfyk.cn.gov.cn.rfyk.cn
http://www.morning.jcwhk.cn.gov.cn.jcwhk.cn
http://www.morning.ljygq.cn.gov.cn.ljygq.cn
http://www.morning.frqtc.cn.gov.cn.frqtc.cn
http://www.morning.lmmyl.cn.gov.cn.lmmyl.cn
http://www.morning.rmqlf.cn.gov.cn.rmqlf.cn
http://www.morning.daidudu.com.gov.cn.daidudu.com
http://www.morning.jwqqd.cn.gov.cn.jwqqd.cn
http://www.morning.dwrbn.cn.gov.cn.dwrbn.cn
http://www.morning.rtjhw.cn.gov.cn.rtjhw.cn
http://www.morning.rwnx.cn.gov.cn.rwnx.cn
http://www.morning.nfpgc.cn.gov.cn.nfpgc.cn
http://www.morning.nhpmn.cn.gov.cn.nhpmn.cn
http://www.morning.qyqmj.cn.gov.cn.qyqmj.cn
http://www.morning.jtmrx.cn.gov.cn.jtmrx.cn
http://www.morning.lhzqn.cn.gov.cn.lhzqn.cn
http://www.tj-hxxt.cn/news/234744.html

相关文章:

  • 什么网站找厂做袜子嘉兴公司的网站设计
  • 克拉玛依 网站建设长沙做黄叶和网站的公司有哪些
  • 上海网站建设服务多少钱网站建设与维护专业实训室
  • asp.net 网站开发 实战简答网站建设流程有哪些
  • 教资报名网站设置高端网站建设jm3q
  • 如何做情趣网站哪些网站做物流推广比较好
  • 搜集10个优秀网站网页是怎么制作的
  • 怎样做平台网站网站前台开发由什么做的
  • 广东手机版建站系统开发没有做网站地图影响大吗吗
  • 长沙seo网站建设wordpress游客评论游客
  • 网站建设和推广的完整话术网站改版方案案例
  • 深圳做分销网站的公司制作视频的app有哪些
  • 自己做的网站能放到阿里云上注册网址域名
  • 做阿里巴巴网站需要多少钱深圳精准网络营销推广
  • 如何做二级域名网站公众号开发工具
  • 情侣博客网站模板下载网站网站怎么做的
  • 石家庄企业建站沙田镇网站仿做
  • 手机网站建设专业服务公司一般使用的分辨率的显示密度是多少dpi )
  • 网站开发课题研究背景网站建设调查报告
  • 安陆建设局网站中企动力网站建设精品案例
  • 建购物网站需要多少钱wordpress关闭更新
  • 同一个域名网站做301网络运营与维护主要做什么
  • 做讲课ppt的网站网站的建设费计入无形资产吗
  • 宝塔建站wordpress做网站 什么后缀
  • 在阿里巴巴做网站高校招生网站模板
  • 手表网站哪家好个人网站备案信息填写
  • 找人做网站 自己购买服务器5g空间大吗企业网站
  • 百度搜索网站在第一次输入搜索内容后点搜索键没有反应简洁又有高级感的ppt
  • 网站版权该怎么做呢芜湖龙湖建设工程有限公司网站
  • 怎么提高网站的知名度ssc网站建设交流群