<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
本篇文章記錄仿寫一個el-divider元件細節,從而有助於大家更好理解餓了麼ui對應元件具體工作細節。本文是elementui原始碼學習仿寫系列的又一篇文章,後續空閒了會不斷更新並仿寫其他元件。原始碼在github上,大家可以拉下來,npm start執行跑起來,結合註釋有助於更好的理解。
github倉庫地址如下:github.com/shuirongshu…
關於分割線的元件,一般使用的場景有:
因為垂直分割距離不夠,所以垂直分割沒有文字描述
我們知道,一個函數,其實就是一個加工流水線,我們入參,經過函數的加工以後,得到return加工後的結果。
對於元件而言,其實也可以當做一個函數(函數式元件),我們傳遞引數,元件props接收,然後元件再根據傳參的不同,渲染出對應的樣式效果。
這種方式和原來的我們使用元件的方式其實差不多,只不過更加精簡,畢竟只考慮接收引數,沒有生命週期、this範例之類的。所以函數式元件的渲染效率會比普通元件高。
所以有些情況下,使用函數式元件效率會更高
比如,通過傳參方式去渲染文字,可以有以下兩種方式
方式一:render函數定義
<script> export default { functional: true, // 一定要指明是函數式元件 props: { bookName: { type: String, default: "鬥破蒼穹", }, }, // context上下文,有點像this的意思。但不一樣 render: function (createElement, context) { // 建立一個h3標籤,標籤內容是上下文物件中的props中的bookName欄位 return createElement("h3", {}, context.props.bookName); }, }; </script>
方式二:template定義
<!-- 模板標籤上加上functional關鍵字表明是函數式元件 --> <template functional> <div> <h3>{{ props.bookName }}</h3> </div> </template> <script> export default { props: { bookName: { type: String, default: "鬥破蒼穹", }, }, } </script>
關於函數式元件的具體細節,詳情見官方檔案:cn.vuejs.org/v2/guide/re…
這裡為什麼要提到函數式元件呢?因為el-divider
元件就是使用函數式元件進行封裝的(因為元件只是做分割線條的展示,所以不需要有this範例,生命週期之類的)
故:為了提升渲染效率,這裡使用函數式元件
使用函數式元件的情況大致有以下:
先看一下問題圖
只需要給對應dom元素稍微縮放一下即可:
transform: scaleY(0.95);
或 transform: scaleX(0.95);
el-divider
元件整體還是比較簡單的,主要是函數式元件的引數使用細節
使用的程式碼
<template> <div class="wrap"> <h3>實線solid靠左</h3> <my-divider class="staticClass_must_hava" content-position="left" >早上好</my-divider > <h3>實線solid居中</h3> <my-divider content-position="center">中午好</my-divider> <h3>實線solid靠右</h3> <my-divider content-position="right">下午好</my-divider> <h3>虛線dashed靠左</h3> <my-divider lineType="dashed" content-position="left">早上好</my-divider> <h3>虛線dashed居中</h3> <my-divider lineType="dashed" content-position="center">中午好</my-divider> <h3>虛線dashed靠右</h3> <my-divider lineType="dashed" content-position="right">下午好</my-divider> <h3>圓點dotted靠左</h3> <my-divider lineType="dotted" content-position="left">早上好</my-divider> <h3>圓點dotted居中</h3> <my-divider lineType="dotted" content-position="center">中午好</my-divider> <h3>圓點dotted靠右</h3> <my-divider lineType="dotted" content-position="right">下午好</my-divider> <h3>豎向分割線</h3> <span>早上好</span> <my-divider direction="vertical"></my-divider> <span>中午好</span> <my-divider direction="vertical"></my-divider> <span>下午好</span> </div> </template> <script> import myDivider from "./myDivider.vue"; export default { components: { myDivider }, }; </script> <style> .wrap { padding: 24px; } .staticClass_must_hava { border-bottom: 1px solid #baf !important; } </style>
封裝的程式碼
<template functional> <!-- functional關鍵字加上後,即代表為函數式元件,就沒有生命週期、this範例等了,故渲染更快,效能更高 --> <!-- v-bind和v-on這裡不加也行。畢竟函數式元件個人愚見簡潔建議一些,attrs存放傳遞來的資料,listeners傳遞任何事件監聽器 --> <!-- data.staticClass需要加上,否則外層給元件加的class屬性在審查元素的時候不會出現的,相當於沒加 --> <div v-bind="data.attrs" v-on="listeners" :class="[data.staticClass, `${props.direction}`, `${props.lineType}`]" > <!-- 當分割線為水平的時候,且插槽有內容的時候,才渲染對應資料 --> <!-- slots()方法返回插槽資料物件,default為預設插槽;相當於this.$slots.default。本系列文章中仿寫一個el-tabs 也提到了此知識點 --> <div v-if="props.direction === 'horizontal' && slots().default" :class="['text', `${props.contentPosition}`]" > <slot /> </div> </div> </template> <script> export default { name: "myDivider", props: { // 分割線的方向,預設水平horizontal(垂直vertical可選) direction: { type: String, default: "horizontal", validator(val) { return ["horizontal", "vertical"].includes(val); }, }, // 文字內容位置,預設居中(僅當分割線為水平方向時,才渲染對應內容) contentPosition: { type: String, default: "center", validator(val) { return ["left", "center", "right"].includes(val); }, }, // 分割線線條型別,預設實線,可選虛線,圓點線 lineType: { type: String, default: "solid", validator(val) { return ["solid", "dashed", "dotted"].includes(val); }, }, }, }; </script> <style lang="less" scoped> // 水平樣式 .horizontal { width: 100%; border-bottom: 1px solid #333; // 預設solid分割線樣式 display: block; margin: 12px 0; position: relative; // 縮放0.95倍可以解決一畫素問題(一畫素看著比實際粗)橫線Y縮放 transform: scaleY(0.95); } // dashed分割線 .dashed { border-bottom: 1px dashed #333; } // dotted分割線 .dotted { border-bottom: 1px dotted #333; } // 垂直樣式 .vertical { display: inline-block; width: 1px; height: 1em; margin: 0 8px; background-color: #333; vertical-align: middle; position: relative; top: -1px; // 微調一下位置 // 縮放0.95倍可以解決一畫素問題(一畫素看著比實際粗)豎線X縮放 transform: scaleX(0.95); } // 文字樣式 .text { position: absolute; padding: 0 12px; color: #333; font-size: 14px; transform: translateY(-50%); // y軸移動自身的一半,使其垂直方向居中 background-color: #fff; // 通過背景色和padding去蓋住水平分割線條 } // 文字靠左 .text.left { left: 36px; } // 文字靠右 .text.right { right: 36px; } // 文字居中 .text.center { left: 50%; // 居中的話,別忘了要回正。即XY軸方向都平移自身的一半 transform: translateX(-50%) translateY(-50%); } </style>
以上就是elementui原始碼學習之仿寫一個el-divider元件的詳細內容,更多關於elementui仿寫el-divider的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45