封裝第三方組件(三)封裝基礎(chǔ)控件

基礎(chǔ)控件

主要指的是表單里面需要的各種組件旗笔。

有些組件比較簡(jiǎn)單蒜哀,一行就可以搞定斩箫,但是有些就需要多寫幾行,這樣就有點(diǎn)麻煩撵儿,比如單選組合復(fù)選組還有下拉選擇等乘客。如果需要聯(lián)動(dòng)的話,就需要更多的代碼淀歇。

封裝基礎(chǔ)控件易核,一個(gè)是為了使用起來(lái)更便捷一些,另一個(gè)也是為封裝表單控件做準(zhǔn)備浪默。

基于element-plusUI庫(kù)牡直,封裝了一些常用的表單子控件,比如這幾個(gè):

基礎(chǔ)控件
  • 控制代碼纳决,打算以后穩(wěn)定了發(fā)包到npm上面碰逸,這些代碼是和UI庫(kù)無(wú)關(guān)的,也就是說(shuō)可以用于其他UI庫(kù)阔加。

  • 表單子控件花竞,基于element-plus的 Form 里面的組件進(jìn)行封裝,以后也可以基于其他UI庫(kù)進(jìn)行封裝。至于會(huì)不會(huì)單獨(dú)發(fā)包到npm约急,這個(gè)看情況零远。

  • map-el-form-item.js,這個(gè)是表單子控件的注冊(cè)用的代碼厌蔽。這么多組件牵辣,一個(gè)一個(gè)注冊(cè)也太麻煩了,所以做了這個(gè)文件奴饮。

按照原子性原則進(jìn)行封裝

原子性原則纬向,也就是一個(gè)組件只做一件事情!
比如密碼組件戴卜,就只負(fù)責(zé)密碼的輸入逾条;
URL組件,就只負(fù)責(zé)url的輸入投剥;
年月的組件师脂,就只負(fù)責(zé)年月的選擇。

這樣每個(gè)組件的代碼都可以很單一江锨,便于維護(hù)和擴(kuò)展吃警。

使用方式

      <el-row>
        <el-col :span="4">文本框</el-col>
        <el-col :span="14">
          <nftext v-bind="propText" v-model="formModel.text"/>
        </el-col>
      </el-row>
      <el-row>
      <el-col :span="4">密碼</el-col>
        <el-col :span="14">
          <nfpwd v-bind="propPwd" v-model="formModel.pwd"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">數(shù)字</el-col>
        <el-col :span="14">
          <nfnumber v-bind="{}" v-model="formModel.num"/>
          </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">滑塊</el-col>
        <el-col :span="14">
          <nfslider v-bind="{}" v-model="formModel.num"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">日期</el-col>
        <el-col :span="14">
          <nfdate v-bind="{}" v-model="formModel.date"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">年</el-col>
        <el-col :span="14">
          <nfyear v-bind="{}" v-model="formModel.year"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">月</el-col>
        <el-col :span="14">
          <nfmonth v-bind="{}" v-model="formModel.month"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">時(shí)間</el-col>
        <el-col :span="14">
          <nftime v-bind="{}" v-model="formModel.time"/>
          </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">顏色</el-col>
        <el-col :span="14">
          <nfcolor v-bind="{}" v-model="formModel.color"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">打鉤</el-col>
        <el-col :span="14">
          <nfcheckbox v-bind="{}" v-model="formModel.checkbox"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">開(kāi)關(guān)</el-col>
        <el-col :span="14">
          <nfswitch v-bind="{}" v-model="formModel.switch"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">評(píng)分</el-col>
        <el-col :span="14">
          <nfrate v-bind="{}" v-model="formModel.rate"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">單選</el-col>
        <el-col :span="11">
          <nfradios v-bind="propChecks" v-model="formModel.radios"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">多選</el-col>
        <el-col :span="13">
          <nfcheckboxs v-bind="propChecks" v-model="formModel.checkboxs"/>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="4">多行</el-col>
        <el-col :span="14">
          <nfarea v-bind="{}" v-model="formModel.area"/>
        </el-col>
      </el-row>
       <el-row>
        <el-col :span="4">URL</el-col>
        <el-col :span="14">
          <nfurl  v-model="formModel.url"/>
          </el-col>
      </el-row>

除了需要選項(xiàng)的組件,其他都不需要設(shè)置屬性啄育,一個(gè)v-model即可酌心。


const propChecks = {
  optionList: [
    {value: 1, label: '選項(xiàng)一'},
    {value: 2, label: '選項(xiàng)二'}
  ]
}


const formModel = reactive({
  text: '',
  area:'',
  pwd: '',
  url: '',
  num: 1,
  date: '',
  year: '2020',
  month: '2021-02',
  time:'',
  checkbox: false,
  switch: false,
  radios:[],
  checkboxs:[],
  color: '',
  rate: 3,
  an: ''
})

話說(shuō),在 script setup 里面怎么使用 ... 解構(gòu)挑豌?

效果:

控件效果

源碼

https://gitee.com/naturefw/nf-vite2-element

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末安券,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子氓英,更是在濱河造成了極大的恐慌侯勉,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件债蓝,死亡現(xiàn)場(chǎng)離奇詭異壳鹤,居然都是意外死亡盛龄,警方通過(guò)查閱死者的電腦和手機(jī)饰迹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)余舶,“玉大人啊鸭,你說(shuō)我怎么就攤上這事∧渲担” “怎么了赠制?”我有些...
    開(kāi)封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我钟些,道長(zhǎng)烟号,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任政恍,我火速辦了婚禮汪拥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘篙耗。我一直安慰自己迫筑,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布宗弯。 她就那樣靜靜地躺著脯燃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蒙保。 梳的紋絲不亂的頭發(fā)上辕棚,一...
    開(kāi)封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音追他,去河邊找鬼坟募。 笑死,一個(gè)胖子當(dāng)著我的面吹牛邑狸,可吹牛的內(nèi)容都是我干的懈糯。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼单雾,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼赚哗!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起硅堆,我...
    開(kāi)封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤屿储,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后渐逃,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體够掠,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年茄菊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了疯潭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡面殖,死狀恐怖竖哩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情脊僚,我是刑警寧澤相叁,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響增淹,放射性物質(zhì)發(fā)生泄漏椿访。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一虑润、第九天 我趴在偏房一處隱蔽的房頂上張望赎离。 院中可真熱鬧,春花似錦端辱、人聲如沸梁剔。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)荣病。三九已至,卻和暖如春渗柿,著一層夾襖步出監(jiān)牢的瞬間个盆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工朵栖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留颊亮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓陨溅,卻偏偏與公主長(zhǎng)得像终惑,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子门扇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容