专栏电商日志财经减肥爱情
投稿投诉
爱情常识
搭配分娩
减肥两性
孕期塑形
财经教案
论文美文
日志体育
养生学堂
电商科学
头戴业界
专栏星座
用品音乐

利用Vue自定义指令让你的开发变得更优雅

  前段时间在用框架开发H5页面时,碰到框架中的组件内置了一个属性用于适配异形屏,虽然是组件内部实现的,但这个方式让我萌生一个想法:能不能自己写一个属性来实现这样的功能?
  经过一番思索,我发现Vue的指令模式就很像属性的写法,在Vue中,我们利用模板指令诸如vifvfor等完成了许多工作,而Vue同样也支持自定义属性:constappVue。createApp({})注册一个全局自定义指令vfocusapp。directive(focus,{当被绑定的元素挂载到DOM中时mounted(el){聚焦元素el。focus()}})
  然后你可以在模板中任何元素上使用新的vfocusattribute,如下inputvfocus
  注:这里除了全局注册,也可以采用局部注册的方式,实际开发中可以使用vue另一项方便的功能mixin来将对应的指令混入你想使用的文件中,以达到代码的复用,那么开始进入正题吧。底部安全区适配
  首先页面必须在head标签中添加meta标签,并设置viewportfitcover值directives:{safeAreaBottom:{bind(el,binding){constaddHighbinding。value0el。setAttribute(style,el。style。cssTextpaddingbottom:calc({addHigh}constant(safeareainsetbottom));paddingbottom:calc({addHigh}env(safeareainsetbottom)););}}}
  使用:
  如果设计图本身存在一个边距,则可以动态适配:
  是不是很方便?我们再来看看另一个移动端H5会遇到的问题,并且还是用Vue指令来解决它。弹窗背景页不滚动
  在移动端开发中,页面弹出滚动窗口时,需要将背景页固定住不动,否则会出现滚动穿透的现象。touchScroll:{inserted(){constscrollTopdocument。body。scrollTopdocument。documentElement。scrollTop;document。body。style。cssTextposition:fixed;width:100;top:scrollToppx;;},unbind(){constbodydocument。bodydocument。documentElement;body。style。position;consttopbody。style。top;document。body。scrollTopdocument。documentElement。scrollTopparseInt(top,10);body。style。top;}}是的,我是一个弹窗,当我出现时我的背景会吓得不敢动实现一个copy工具
  有时我们需要页面点击可以一键复制的功能,可能大家都有用到一个叫vueclipboard的库,知道了指令的使用,实现一个copy自然也不在话下,那么就自己动手写一个vueCopy,为今后开发项目减少一个第三方库的使用吧。
  首先我们看看这个工具是怎么使用的:
  可以看出作者也是利用了指令,就照他这个思路,动手撸了一个,这里就直接上代码了,具体思路点见注释:clipboard:{bind(el,binding,{context}){constthiscontext利用arg用来注入回调函数if(binding。argsuccess){this。clipboardSuccessthis〔binding。expression〕}elseif(binding。argerror){this。clipboardErrorthis〔binding。expression〕}else{正常情况下就将文字缓存起来this。clipboardValuebinding。value}el。handler(){if(!this。clipboardValue){this。clipboardErrorthis。clipboardError(无内容)return}if(binding。arg){这里是因为属性被我们用了多次会多次执行,所以限制了执行次数return}try{consttextareadocument。createElement(textarea)textarea。readOnlyreadonly禁止输入,readonly防止手机端错误聚焦自动唤起键盘textarea。setAttribute(style,position:fixed;top:9999px;left:9999px;)它是可见的,但它又是不可见的textarea。valuebinding。valuedocument。body。appendChild(textarea)textarea。select()constresultdocument。execCommand(Copy)if(result){this。clipboardSuccessthis。clipboardSuccess(binding。value)这里可以定义成功回调返回的数据}document。body。removeChild(textarea)}catch(e){this。clipboardErrorthis。clipboardError(e)}}el。addEventListener(click,el。handler)},componentUpdated(el,{arg,value},{context}){更新值时候触发constthiscontextif(!arg){注册回调的部分不要赋值this。clipboardValuevalue}},unbind(el){el。removeEventListener(click,el。handler)},}
  简单使用:点击直接复制到剪贴板
  带回调的使用:templatecopycopyTexttemplate表单防止重复提交设置vthrottle自定义指令Vue。directive(throttle,{bind:(el,binding){letthrottleTimebinding。value;节流时间if(!throttleTime){用户若不设置节流时间,则默认2sthrottleTime2000;}letcbFun;el。addEventListener(click,event{if(!cbFun){第一次执行cbFunsetTimeout((){cbFunnull;},throttleTime);}else{eventevent。stopImmediatePropagation();}},true);},});
  使用:buttonclicksayHellovthrottle提交button图片懒加载constLazyLoad{install方法install(Vue,options){代替图片的loading图letdefaultSrcoptions。default;Vue。directive(lazy,{bind(el,binding){LazyLoad。init(el,binding。value,defaultSrc);},inserted(el){兼容处理if(IntersectionObserverinwindow){LazyLoad。observe(el);}else{LazyLoad。listenerScroll(el);}},})},初始化init(el,val,def){datasrc储存真实srcel。setAttribute(datasrc,val);设置src为loading图el。setAttribute(src,def);},利用IntersectionObserver监听elobserve(el){letionewIntersectionObserver(entries{letrealSrcel。dataset。src;if(entries〔0〕。isIntersecting){if(realSrc){el。srcrealSrc;el。removeAttribute(datasrc);}}});io。observe(el);},监听scroll事件listenerScroll(el){lethandlerLazyLoad。throttle(LazyLoad。load,300);LazyLoad。load(el);window。addEventListener(scroll,(){handler(el);});},加载真实图片load(el){letwindowHeightdocument。documentElement。clientHeightletelTopel。getBoundingClientRect()。top;letelBtmel。getBoundingClientRect()。bottom;letrealSrcel。dataset。src;if(elTopwindowHeight0elBtm0){if(realSrc){el。srcrealSrc;el。removeAttribute(datasrc);}}},节流throttle(fn,delay){lettimer;letprevTime;returnfunction(。。。args){letcurrTimeDate。now();letcontextthis;if(!prevTime)prevTimecurrTime;clearTimeout(timer);if(currTimeprevTimedelay){prevTimecurrTime;fn。apply(context,args);clearTimeout(timer);return;}timersetTimeout(function(){prevTimeDate。now();timernull;fn。apply(context,args);},delay);}}}exportdefaultLazyLoad;
  以上就是文章的全部内容,希望对你有所帮助!如果觉得文章写的不错,可以点赞收藏,也欢迎关注,我会持续更新更多前端有用的知识与实用技巧,我是茶无味de一天,希望与你共同成长

经脉不通,百病丛生,张仲景通脉方通脉散寒,治肢体冷痛抽筋大家好,我是屈医生。中医上有句话叫做脉通一寸,延寿一年,今天给大家分享一个张仲景独传的通脉方,专治肢体冷痛抽筋。经脉是我们人体气血运行的重要通道,道路畅通气血运行才能畅通,我们身体在肚子里,胎儿会尿尿?关于未出生婴儿的7个鲜为人知的事实婴儿需要在妈妈的肚子里经历多个阶段才能够成形,当孩子出生以后的每一天,我们都可以看到婴儿发生的许多惊人变化。可事实上,当婴儿还未出生的时候,就已经发生了许多神奇的事情。例如他们可能人类母乳中首次发现微塑料,对婴儿的潜在影响仍未知根据发表在聚合物(Polymers)英国化学期刊的一项最新研究表明,意大利马尔凯理工大学研究人员征集了34名女性的母乳样本,她们都刚分娩一周且身体健康,其中75的样本中检测到了微塑华为5G通信壳,全是智商税?你抢到华为手机了吗?9月21日,华为Mate50手机正式开售。线上平台华为商城的热销机型10秒内售罄。另外,根据网友曝光的画面来看,华为的各种线下店铺也是大排长龙,销售火爆。根据业下一个雷曼兄弟?瑞士信贷陷破产危机,或波及全球文陈九霖陈百应2022年的瑞士信贷集团(以下简称瑞士信贷或瑞信)最近有可能发生暴雷的新闻,被拱上了热搜。而这也让人们又一次联想到了2008年的雷曼兄弟(雷曼)破产事件。而瑞士信贷的大腿!周琦重返凤凰全队列队欢迎,队长克里克熊抱大喊爸爸爸爸10月11日消息,澳大利亚时间10月10日,中国男篮中锋周琦重返墨尔本凤凰,回归球队之后,周琦受到了全队列队欢迎,有趣的是,逗比队长里奇克里克冲周琦大喊爸爸,把周琦当大腿抱了!周琦36氪首发光梓科技完成数千万C1轮融资,专注高性能光电通讯和传感芯片作者杨逍近日,36氪获悉,光电集成电路芯片设计企业光梓科技获得由浩澜资本领投,申能集团旗下申能诚毅和老股东华登国际跟投的数千万C1轮融资。据悉,本轮融资将主要用于产品研发投入和公司玩具之都,广东汕头澄海玩具市场会消失吗?生意太难做了,客户不下单怎么办?今天人民币汇率又回到7。2,贬值新高!空空的市场疫情只是外因,消失的就业才是主因,购买力减少是主因。美国只看非农就业数据!人人有工作,人人有消费换句WWE首位中国女将李霞三围比例出众,一袭旗袍深受观众喜爱摔角是格斗赛的一种,与摔跤等类似,但又有自己的特色,盛行于欧美,国内很少见到相关的消息。世界摔角娱乐(WWE)是摔角竞技领域最大的一家公司,早在2010年,WWE就有向中国市场进军试驾智己L7,在操控中寻觅新生一款售价近50万元的纯电动轿车,其属性会是什么?有人说,应该像蔚来ET7那般将用户捧在手心里,堆料将自我身价抬高有人说,或将像沙龙机甲龙,从外及里均不按常理出牌的手法,才是最适合当新生儿胀气怎么解决?这五个小妙招快速缓解宝宝胀气一到下午四五点就开始闹,扭来扭去还老是哭腹部较硬,放屁多,还臭睡觉也不踏实,翘脚还容易醒你们家宝宝是不是也经常出现以上情况,那八九不离十,基本上就是宝宝胀气了。胀气是新生儿宝宝常见
中国纳税最多的8大企业!华为第3,中国烟草第1,相当于30个恒大这几日,中国纳税排名新鲜出炉,令人震惊的是,第1名纳税居然超过了万亿,还是第8名纳税总额的30倍,每天纳税高达32个亿。更令人吃惊的是,纳税最多的房企,不是万科,也不是碧桂园,竟然中国邮储总行录用60人,人大登顶,上财仅1人,近九成为京内高校中国邮政储蓄银行总行公布了2022年录用的60名应届毕业生名单,其中顶尖财经院校人大有15人录取,排在了首位,央财和贸大也紧随其后表现亮眼!而上财则仅有1人,因为录取的近九成都是京2022年9月中国采购经理指数运行情况国家统计局服务业调查中心中国物流与采购联合会一中国制造业采购经理指数运行情况9月份,制造业采购经理指数(PMI)为50。1,比上月上升0。7个百分点,升至扩张区间。从企业规模看,大哀兵也未必能必胜,中国女篮力压打疯了的法国队,怎么做到的?生死战一般很难拿过往的数据来衡量,只有即时的出色状态才是决胜的要素。第三节法国队打得异常的疯狂,一度追至仅差一分,这还是我们印象中,在预选赛上遭遇到的那支输了33分的球队吗!按照央女排迎战捷克队,国际排联发文盛赞中国女排,蔡斌摊牌争冠加码恭喜王云璐!恭喜王梦洁,中国女排双喜临门,蔡斌摊牌争冠加码2022年女排世锦赛继续展开,中国女排会在9月30日晚上8点打响对阵捷克女排的比赛,在赛前蔡斌也收获了好消息。北京时间9月挺进四强!祝贺中国女篮9月29日,中国队球员杨力维(右)在比赛中带球突破。新华社发(胡泾辰摄)中国女篮击败法国队晋级世界杯四强29日,在2022年女篮世界杯四分之一决赛中,中国队以8571击败法国队,晋中国供销集团原副董事长管爱国被双开中央纪委国家监委网站讯据中央纪委国家监委驻中华全国供销合作总社纪检监察组江苏省监察委员会消息日前,中央纪委国家监委驻中华全国供销合作总社纪检监察组江苏省监察委员会对中国供销集团原副红杉资本和葛卫东重仓押注,中国新能源汽车卷王,零跑成功上市领跑汽车终于还是上市了,港股的新能源汽车第一股来啦!零跑汽车成功上市为什么说是港股新能源汽车第一股,因为跟蔚小理海外红筹架构不同,零跑科技是以中国境内架构直接在香港发行H股,可以算山东3岁以下婴幼儿父母各享每年不少于10日育儿假近日,山东省委省政府印发优化生育政策促进人口长期均衡发展实施方案。方案指出,积极有序实施三孩生育政策。将入户入学入职信用等与个人生育情况全面脱钩。依法依规妥善处理历史遗留问题,促进10岁男童连续3年睡前喝奶,身高只有109厘米?或是无知父母害了他想必在生活当中很多家长会让孩子孩子喝奶,不管是在小学还是幼儿园,孩子的生长发育需要足够的营养,除了牛奶有较高营养外,还要其他营养较高的食物,比如肉类,鸡蛋等,都是促进孩子生长发育的小小中国娃浓浓中国情金秋十月,孩子们带着祝福带着希望迎来了祖国妈妈的生日。为了让孩子们更好的了解国庆节的意义,培养对祖国的热爱之情,在国庆佳节来临之际,巨幼师生开展了小小中国娃浓浓爱国情国庆节活动。一
友情链接:快好找快生活快百科快传网中准网文好找聚热点快软网