溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

elementui如何仿寫el-link

發(fā)布時間:2022-12-28 15:12:15 來源:億速云 閱讀:139 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下elementui如何仿寫el-link的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

組件的需求

  • link組件加上不同類型的鏈接樣式,比如普通樣式、成功樣式、警告樣式、危險樣式的鏈接樣式

  • link組件加上鼠標(biāo)懸浮時下劃線。封裝組件中使用的是偽元素搭配border-bottom實(shí)現(xiàn)的

  • 通過傳參去控制link組件什么時候有下劃線,什么時候沒有下劃線

  • 另外,也需要考慮組件會被禁用,禁用時,不能點(diǎn)擊,不能跳轉(zhuǎn),且更換一下樣式效果

  • 同時,link組件跳轉(zhuǎn)鏈接時的一些操作

  • 也要是考慮到link組件需要搭配小圖標(biāo)去使用(本例中以餓了么icon為例)

組件的效果圖

elementui如何仿寫el-link

組件實(shí)現(xiàn)分析

給link組件加上鏈接樣式

這里使用動態(tài)class的數(shù)組用法去控制,如下簡單例子:

// html
<a
  :class="[
    'myLink',
    type
]"
>
// js
props:{
    type: String, // 標(biāo)簽顏色的類型
}
// css
.primary { color: #2d8cf0; }
.success { color: #19be6b; }
.warning { color: #f90; }
.danger { color: #ed4014; }

由上,比如傳遞的type參數(shù)值為success,那么a標(biāo)簽就會加上一個success的類名,這樣的話,就會找到對應(yīng)css中的類名,從而呈現(xiàn)相應(yīng)的顏色效果(當(dāng)然type的值在底下css中要有對應(yīng)的)

給link組件加上鼠標(biāo)懸浮時下劃線

其實(shí)類似這種,懸浮下劃線,懸浮上劃線,懸浮特殊背景控制。大致可以歸納為在主要dom旁邊加上一個小東西,都可以考慮使用偽元素

關(guān)于啥是偽元素,這里不贅述

我們看下方的鼠標(biāo)懸浮上劃線和下劃線的效果圖,這個效果圖就是使用偽元素搭配定位以及border去實(shí)現(xiàn)的

elementui如何仿寫el-link

代碼:

// css
span {
     font-size: 24px;
     position: relative;
}
span:hover::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 0;
    /* 定位控制 */
    top: 2px;
    border-top: 1px solid red;
}
span:hover::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 0;
    /* 定位控制 */
    bottom: -2px;
    border-bottom: 1px solid red;
}
// html
<span>早上好,程序猿獸們</span>

通過傳參控制是否加上下劃線(即:是否加上這個下劃線類名)

這里依然是使用動態(tài)class的數(shù)組用法,在數(shù)組中書寫四元表達(dá)式,簡約代碼如下:

<a
    :class="[
      'myLink',
       hideUnderline ? '' : disabled ? '' : 'underline'
    ]"
  >

大意:即不去隱藏下劃線,又不去禁用這個link組件的時候,才加上underline類名,才產(chǎn)生下劃線

使用v-bind="$attrs"兜底a標(biāo)簽的其他的未在props中聲明的參數(shù)

<a
    :href="disabled ? null : href" rel="external nofollow"  rel="external nofollow" 
    v-bind="$attrs"
  >

我們知道a標(biāo)簽中有很多原生屬性,如下圖:

elementui如何仿寫el-link

這么多a標(biāo)簽的屬性,我們不可能在封裝的組件的時候,如果把每一個屬性都在props中聲明,倒是有些麻煩。所以此時$attr就應(yīng)運(yùn)而生了。關(guān)于$attr$listener的用法,這里也不贅述,大家只要記得$attr是做參數(shù)屬性兜底的即可。

代碼

演示的話,直接復(fù)制粘貼即可,結(jié)合注釋更好理解。注意my-divider組件是之前封裝的組件。

使用代碼

<template>
  <div class="box">
    <my-divider lineType="dashed" content-position="left"
      >五種鏈接樣式</my-divider
    >
    <my-link>默認(rèn)超鏈接</my-link>
    <my-link type="primary">primary超鏈接</my-link>
    <my-link type="success">success超鏈接</my-link>
    <my-link type="warning">warning超鏈接</my-link>
    <my-link type="danger">danger超鏈接</my-link>
    <my-divider lineType="dashed" content-position="left"
      >是否有下劃線</my-divider
    >
    <my-link>默認(rèn)有下劃線</my-link>
    <my-link hideUnderline>也可隱藏下劃線</my-link>
    <my-divider lineType="dashed" content-position="left"
      >禁用鏈接樣式</my-divider
    >
    <my-link disabled>禁用|默認(rèn)超鏈接</my-link>
    <my-link type="primary" disabled>禁用|primary超鏈接</my-link>
    <my-link type="success" disabled>禁用|success超鏈接</my-link>
    <my-link type="warning" disabled>禁用|warning超鏈接</my-link>
    <my-link type="danger" disabled>禁用|danger超鏈接</my-link>
    <my-divider lineType="dashed" content-position="left"
      >添加href和target原生屬性</my-divider
    >
    <my-link type="primary" href="https://www.baidu.com/" rel="external nofollow" >默認(rèn)self跳轉(zhuǎn)</my-link>
    <my-link type="success" target="_blank" href="https://cn.bing.com/" rel="external nofollow" 
      >支持原生屬性target等</my-link
    >
    <my-divider lineType="dashed" content-position="left"
      >通過icon屬性或者直接在默認(rèn)插槽中添加圖標(biāo)</my-divider
    >
    <my-link type="primary" icon="el-icon-share">默認(rèn)圖標(biāo)在前方</my-link>
    <my-link type="success" icon="el-icon-share" back
      >back屬性控制圖標(biāo)在后方</my-link
    >
    <my-link type="primary"
      ><i class="el-icon-goods"></i>默認(rèn)插槽前方加圖標(biāo)</my-link
    >
    <my-link type="success"
      >默認(rèn)插槽后方加圖標(biāo) <i class="el-icon-goods"></i
    ></my-link>
    <my-divider lineType="dashed" content-position="left"
      >綁定事件使用</my-divider
    >
    <my-link @click="clickThis" type="danger" icon="el-icon-aim"
      >點(diǎn)擊這個哦</my-link
    >
  </div>
</template>
<script>
export default {
  methods: {
    clickThis() {
      console.log("注意:當(dāng)myLink禁用或有href屬性時,點(diǎn)擊事件失效");
    },
  },
};
</script>

封裝組件代碼

<template>
  <!-- 
       hideUnderline ? '' : disabled ? '' : 'underline',
       先看hideUnderline是否為true,為true則要隱藏下劃線,即不加underline類名
       再看disabled是否為true,為true則禁用,禁用也要隱藏下劃線,即也不加underline類名
       若既不隱藏下劃線又不禁用鏈接,則加上underline類名用于顯示下劃線
   -->
  <a
    :href="disabled ? null : href" rel="external nofollow"  rel="external nofollow" 
    :class="[
      'myLink',
      hideUnderline ? '' : disabled ? '' : 'underline',
      type,
      disabled ? 'toDisabled' : '',
    ]"
    v-bind="$attrs"
    @click="handleClick"
  >
    <!-- 
       這里加上v-bind="$attrs"是為了傳遞更多的屬性,做一個參數(shù)兜底的功能效果。因?yàn)閍標(biāo)簽還有其他很多屬性,如:
       target、download、type等。props中未聲明的參數(shù),會被$attr兜底交給a標(biāo)簽使用。故加了v-bind="$attrs"以后,
       在外層my-link標(biāo)簽上,我們便可正常使用除props中聲明的屬性了,如使用target原生屬性:<my-link target="_blank" href="xxx" rel="external nofollow" />
    -->
    <!-- 內(nèi)容區(qū) -->
    <span class="aContent" :class="{ spaceC: icon, back: back }">
      <i :class="icon" v-if="icon"></i>
      <span><slot></slot></span>
    </span>
  </a>
</template>
<script>
export default {
  name: "myLink",
  props: {
    href: String, // a標(biāo)簽的href屬性,用于跳轉(zhuǎn)
    disabled: Boolean, // 是否禁用超鏈接
    type: String, // 標(biāo)簽顏色的類型
    // 是否隱藏下劃線
    hideUnderline: {
      type: Boolean,
      default: false, // 默認(rèn)不隱藏下劃線,默認(rèn)展示下劃線
    },
    icon: String, // 使用餓了么UI的小圖標(biāo)
    back: Boolean, // 設(shè)置圖標(biāo)在內(nèi)容后方
  },
  methods: {
    handleClick(event) {
      // 禁用狀態(tài)下不允許傳遞事件
      if (this.disabled) {
        return;
      }
      // 有鏈接了也不允許傳遞事件
      if (this.href) {
        return;
      }
      // 沒有禁用沒有鏈接,便可正常傳遞事件
      this.$emit("click", event);
    },
  },
};
</script>
<style lang="less" scoped>
// 默認(rèn)樣式
.myLink {
  display: inline-block;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: #666; // 默認(rèn)顏色,當(dāng)然也可以使用type類型的配色
  text-decoration: none; // 去除a標(biāo)簽?zāi)J(rèn)的下劃線(不使用自帶的下劃線效果)
  position: relative; // 定位搭配偽元素實(shí)現(xiàn)懸浮下劃線效果
  margin: 4px;
  .aContent {
    display: flex;
    align-items: center;
  }
  // 當(dāng)傳的有圖標(biāo)的時候,把第一個元素加上一個右邊距,產(chǎn)生間距
  .spaceC > :first-child {
    margin-right: 4px;
  }
  // 控制彈性盒方向,控制圖標(biāo)在后方位置(默認(rèn)前方位置)
  .back {
    flex-direction: row-reverse;
  }
  // 注意這里要覆蓋上方spaceC的樣式
  .back > :first-child {
    margin: 0 0 0 4px;
  }
}
// 通過變量控制是否有這個underline類名,從而控制是否有下劃線
.underline:hover::after {
  // 這樣的話,元素在哪,下劃線就在哪里
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 0;
  bottom: -2px;
  // 注意,這里不設(shè)置顏色,就會跟隨參考定位的元素的顏色了
  border-bottom: 1px solid;
}
// 下方的配色是抄iview的
.primary {
  color: #2d8cf0;
}
.success {
  color: #19be6b;
}
.warning {
  color: #f90;
}
.danger {
  color: #ed4014;
}
// 通過透明度模擬禁用的顏色樣式效果,要不然要寫兩份顏色會稍微麻煩一些
.toDisabled {
  opacity: 0.36;
  cursor: not-allowed;
}
</style>

以上就是“elementui如何仿寫el-link”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI