Vue封装组件-通用面板-LjPanel

 

  1. 作为底板时,通常设置属性:padding:10px;并设置关闭按钮可见::isShowBtnClose="true"

 使用:

      <LjPanel
        title="标题"
        v-if="isDkInfoPanelVisible"
        :isShowTitle="false"
        :isShowBtnClose="true"
        @closePanel="closeDkInfoPanel"
        width="600px"
        padding="10px"
        >
        内容
      </LjPanel>

LjPanel.vue:

<!--LjPanel-->
<template>
  <div class="LjPanel" :style="{ padding: padding, width: width }">
    <div class="LjPanelHead" :style="{ color: headColor }">
      <span v-if="isShowTitle">{{ title }}</span>
      <span class="btnClose" v-if="isShowBtnClose" @click="btnClose()">x</span>
    </div>
    <div class="content">
      <slot></slot>
    </div>
  </div>
</template>

<script>
export default {
  name: "LjPanel",
  components: {},
  props: {
    title: {
      type: String,
      default: "title",
    },
    width: {
      type: String,
      default: "100%",
    },
    headColor: {
      type: String,
      default: "orange",
    },
    padding: {
      type: String,
      default: "0px",
    },
    isShowBtnClose: {
      type: Boolean,
      default: false,
    },
    isShowTitle: {
      type: Boolean,
      default: true,
    },
  },
  data() {
    return {};
  },
  computed: {},
  created() {},
  mounted() {},
  filters: {},
  methods: {
    btnClose() {
      this.$emit("closePanel");
    },
  },
  watch: {},
};
</script>

<style lang="scss" scoped>
.LjPanel {
  background-color: rgba(41, 41, 41, 0.589);
  color: white;
  .LjPanelHead {
    line-height: 40px;
    border-left: 5px solid;
    font-weight: bold;
    padding-left: 10px;
    font-size: 20px;
    background-color: rgba(36, 36, 36, 0.685);
    caret-color: transparent;

    .btnClose {
      float: right;
      padding-right: 10px;
      &:hover {
        cursor: pointer;
        color: rgb(185, 30, 9);
      }
    }
  }
  .content {
    padding: 10px;
  }
}
</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值