vue 自定指令生成uuid滚动监听达到tab表格吸顶效果的代码
                (编辑:jimmy 日期: 2025/10/27 浏览:3 次 )
            
            
            utils/index,.js
/**
 * 生成UUID
 * @param withSeparator 是否有分割符
 * @returns {string}
 */
export function generateUUID(withSeparator = true) {
 let d = new Date().getTime()
 if (window.performance && typeof window.performance.now === 'function') {
  d += performance.now()
 }
 const tpl = withSeparator "htmlcode">
import { generateUUID } from '@/utils'
const generateUuid = {
 inserted(el, binding) {
  const { value } = binding
  if (!value) {
   const hasUUID = generateUUID(value)
   el.setAttribute('data-uuid', hasUUID)
   if (!hasUUID) {
    el.parentNode && el.parentNode.removeChild(el)
   }
  }
 }
}
generateUuid.install = function(Vue) {
 Vue.directive('generate-uuid', generateUuid)
}
 
export default generateUuid
main.js引入
import GenerateUUID from '@/directive/generate-uuid'
Vue.use(GenerateUUID)
页面使用
<el-table
   v-generate-uuid="false"
  >
使用uuid元素方法
const topRow = this.$refs.multipleTable
   const hash = topRow.$el.dataset.uuid
   const tableHeader = document.querySelector(`.el-table[data-uuid="${hash}"] .el-table__header-wrapper`)
   if (tableHeader) {
    tableHeader.style.width = topRow.$el.getBoundingClientRect().width + 'px'
   }
总结
下一篇:vue中选中多个选项并且改变选中的样式的实例代码

