【项目实践-03】实验室PC

透传属性

透传属性指组件在使用的时候,作用在组件上的属性,会被向下流动,绑定到组件内的标签中。

可以透传的属性:style,class,id,属性,事件

当一个组件有多个根标签节点时,那么这个组件就不会有自动透传绑定属性行为

所以如果想利用组件的透传,就必须保证组件内部只有一个根标签

问题:在实验室项目pc端中想利用 v-hasPermi 为导入按钮增加权限,但发现加了权限之后并未生效,导入组件(SyImport) 代码如下:

html 复制代码
    <el-button type="primary" @click="handleUpload">
      {{ props.label }}
    </el-button>
    <el-dialog
      v-model="uploadDialogVisible"
      title="导入"
      width="40%"
      align-center
      :close-on-click-modal="false"
      :before-close="uploadDialogClose"
    >
      <div class="content-wrap">
        <div class="main-wrap">
          <div class="msg-wrap">
            <div v-if="props.explain" class="explain-wrap">
              导入说明:
              <div class="explain-text">
                {{ props.explain }}
              </div>
            </div>
            <div v-if="props.template.url" class="download-wrap" @click="getExcelTemplate">
              点击下载导入模板
            </div>
          </div>
          <div class="upload-wrap" :class="{ 'drag-wrap': !props.drag }">
            <el-upload
              ref="uploadRef"
              :accept="props.accept"
              :drag="props.drag"
              :http-request="requestUpload"
              :auto-upload="false"
              :multiple="props.multiple"
              :limit="props.limit"
              :on-exceed="handleExceed"
            >
              <el-icon class="el-icon--upload">
                <UploadFilled />
              </el-icon>
              <div class="el-upload__text">
                <span v-if="props.drag">拖拽文件到此 或者 </span><em>点击此处上传</em>
              </div>
              <template #tip>
                <div class="el-upload__tip">
                  请选择导入文件
                </div>
              </template>
            </el-upload>
          </div>
        </div>
        <div class="footer-wrap">
          <el-button type="primary" :loading="submitLoading" @click="submitUpload">
            确认导入
          </el-button>
        </div>
      </div>
    </el-dialog>

由此可看出:组件内部有多个根标签,Vue 不知道为哪个标签绑定透传属性,所以v-hasPermi不会生效。

修改:在组件内部添加一个根标签,将这两个标签都放在根标签里,由此问题解决。

相关推荐
Martin -Tang1 分钟前
uniapp 实现录音操作,长按录音,放开取消
前端·javascript·vue.js·uni-app·css3·录音
ZC跨境爬虫22 分钟前
跟着 MDN 学 HTML day_58:(构建行星数据表——HTML表格高级实战指南)
前端·javascript·ui·html·音视频
kyriewen26 分钟前
用户打开飞行模式都能打开你的网站?Service Worker 做离线缓存,PWA 实战
前端·javascript·面试
栉甜38 分钟前
APIs学习
前端·javascript·css·学习·html
zithern_juejin1 小时前
ES6——Symbol
javascript
代码煮茶1 小时前
Vue3 组件库二次封装实战 | 基于 Element Plus 封装企业级 UI 组件库
前端·javascript·vue.js
shen_1 小时前
JS语法:生成器和可迭代对象
javascript
之歆2 小时前
DAY_11JavaScript BOM与DOM深度解析:底层原理与工程实践(上)
开发语言·前端·javascript·ecmascript
逆yan_2 小时前
🧭 基于 pnpm Workspace 和 Turborepo 的 Monorepo 最佳实践
前端·javascript·架构
Nturmoils2 小时前
书签真正难的不是收藏,而是找回来:我是怎么做这个 Chrome 插件的
javascript·后端·浏览器