vue element-ui中popover弹出框 内容content使用slot实现

2 篇文章 1 订阅
2 篇文章 0 订阅

最近写代码用到popover,但是我需要popover的内容content是动态变化的,查看popover定义的相关参数,提到了content
官方说明是:
content 显示的内容,也可以通过 slot 传入 DOM String
我一看到slot就害怕,然后找到了这篇文章链接: https://www.jianshu.com/p/d4f36ee0598d.
写的很详细,主要是有实例,就算不懂slot,也可以套,开心!
我对slot其实还是很迷糊–——就先简单先认为他是一个占位符
按着别人的叙述做几个例子叭

创建使用组件的方式

使用slot涉及到组件的使用,简单的列出了三种方式。

//script代码
  //方式一如下
var kun = Vue.extend({template: `<el-button type="success">伤心</el-button>`})
  Vue.component("kun",kun)
  //方式二如下
  Vue.component("yang",{template:'#template-second'})
  //方式三如下
  Vue.component("meili", Vue.extend({
    template: `<el-button type="success">快乐</el-button>`
  }))
  var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!',
  }
})
//方式二的html代码,注意template不要放在你vue对象中,我创建的vue对象是app,那么我的template就不会放在app中,
<body>
  <div id="app">
  <yang></yang>
    //.........
  </div>
  <template id="template-second">
      <div>
        <ul>
          <li>汉堡</li>
          <li>牛奶</li>
          <li>甜甜圈</li>
        </ul>
      </div>
    </template>
</body>

popover的使用

popover也属于一个组件,只是官方给封装好了,引入之后,直接使用就好,不需要再注册了。也就是说上面的那几种方式自定义组件需要用到,我们用ui组件库是不需要的啦!

<el-popover
    placement="top-start"
    title="标题"
    width="200"
    trigger="hover"
    content="这是一段内容,这是一段内容,这是一段内容,这是一段内容。">
    <el-button slot="reference">hover 激活</el-button>
  </el-popover>

content内容是写死的,我的需求是content内容动态变化的,这里就需要使用插槽。官方说content可以通过slot传入dom,这个slot咋用啊,我的天
源码

<template>
  <span>
    <transition
      :name="transition"
      @after-enter="handleAfterEnter"
      @after-leave="handleAfterLeave">
      <div
        class="el-popover el-popper"
        :class="[popperClass, content && 'el-popover--plain']"
        ref="popper"
        v-show="!disabled && showPopper"
        :style="{ width: width + 'px' }"
        role="tooltip"
        :id="tooltipId"
        :aria-hidden="(disabled || !showPopper) ? 'true' : 'false'"
      >
        <div class="el-popover__title" v-if="title" v-text="title"></div>
        <slot>{{ content }}</slot>
      </div>
    </transition>
    <slot name="reference"></slot>
  </span>
</template>

使用slot

<el-popover
    placement="top-start"
    title="我想吃"
    width="400"
    trigger="hover"
  >
  //slot插入
    <ul>
      <li>
     {{message}}//可以动态变化了
      </li>
    </ul>
  //插入结束
    <el-button slot="reference">
      点一个
    </el-button>
  </el-popover>

神奇!

  • 14
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
实现vue element-ui的dialog边放大缩小,可以使用CSS的transform属性和transition属性来达到效果。具体实现步骤如下: 1. 首先,在dialog组件添加一个div元素作为边,设置其样式为绝对定位、宽高100%、边的宽度和颜色等。 2. 然后,使用CSS的transform属性和transition属性来实现放大缩小效果。将div元素的transform属性设置为scale(1)(原始大小),并设置transition属性为all 0.3s ease-in-out(缩放动画时间和缓动效果)。 3. 最后,在需要放大缩小边的时候,使用Vue的$refs来获取到该div元素,并将其transform属性设置为scale(1.2)(放大)或scale(1)(缩小)即可。 下面是一个简单的示例代码: ``` <template> <el-dialog :visible.sync="dialogVisible" :title="title" :width="width" :before-close="handleClose"> <div class="dialog-border" ref="border"></div> <div>{{ content }}</div> </el-dialog> </template> <script> export default { data() { return { dialogVisible: false, title: 'Dialog标题', width: '50%', content: 'Dialog内容' } }, methods: { handleClose(done) { this.$refs.border.style.transform = 'scale(1)'; setTimeout(() => { done(); }, 300); }, handleClick() { this.dialogVisible = true; this.$refs.border.style.transform = 'scale(1.2)'; } } } </script> <style scoped> .dialog-border { position: absolute; width: 100%; height: 100%; border: 2px solid #409EFF; top: 0; left: 0; transform: scale(1); transition: all 0.3s ease-in-out; } </style> ``` 以上代码仅供参考,具体实现方式可以根据实际需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值