仲灏小栈 仲灏小栈
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

仲灏

诚意, 正心, 格物, 致知
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 《前端项目基础建设》
  • HTML&CSS

  • JavaScript&TypeScript

  • Node

  • 构建

  • Vue

    • 持久化存储实时读取
    • vue自适应布局
    • Vue 中后台表格的增删改查统一解决方案(mixin版)
    • Vue 中后台表格的增删改查同一解决方案(组件封装版)
    • Vue Render自定义table单元格内容
    • 项目初始化编码规范(eslint,prettier等)
    • vue element-ui 换肤功能开发
    • vue element 定义多种主题实现换肤
    • 大屏自适应容器
    • el-upload 自定义上传进度
    • vue3初学注意点
    • vue3 hooks 自适应可视化大屏
    • vue3 element-plus ant- design 自定义主题
    • 博客开发
    • vue2中使用jsx
    • Vue 放弃繁琐的render函数,拥抱JSX
    • 组件设计步骤
      • 分析组件
    • 倒计时验证
    • Vue中computed和watch的区别
    • vue3面试聚焦
    • Vue3 原理 Proxy实现响应式
  • React

  • 小程序

  • 跨端

  • Electron

  • WebGL&GIS

  • 浏览器

  • 面经

  • 其他

  • 大前端
  • Vue
仲灏
2023-09-17
目录

组件设计步骤

# 分析组件

  1. 建立组件的模板,先把架子搭起来,命名约定,组件样式,考虑好组件的基本逻辑。
  2. 组件的数据输入,即定好 props 里面的数据类型。
  3. 组件的数据输出,即对外暴露出来的方法和数据。

例如:

img

从大到小

<template>
  <el-container class="table_container">
    <slot name="header">
      //
    </slot>

    <el-main class="table_main">
      <el-table
        v-loading="loading"
        element-loading-text="拼命加载中"
        element-loading-spinner="el-icon-loading"
        element-loading-background="rgba(255, 255, 255, 0.7)"
        :height="height"
        :data="data"
        style="width: 100%"
      >
        <slot name="columnFirst">
          <!-- <el-table-column type="expand">
            <template slot-scope="props">
              //
            </template>
          </el-table-column>-->
        </slot>

        <slot name="columns">
          <template>
            <el-table-column
              v-for="(col, idx) in columns"
              :key="idx"
              :width="col.width"
              :type="col.type"
              :prop="col.prop"
              :label="col.label"
              :formatter="col.formatter"
            >
              <!-- <template slot-scope="scope">
                <component :is="item.temp.tag" :src="scope.row[item.prop]" />
              </template>-->
            </el-table-column>
          </template>
        </slot>

        <slot name="columnOther" />

        <slot name="columnHandler">
          <el-table-column width="100" label="操作">
            <template slot-scope="scope">
             //
          </el-table-column>
        </slot>
      </el-table>
    </el-main>

    <el-footer class="table_pagination">
      <el-pagination
        :current-page="currentPage"
        :page-sizes="[10, 20, 50, 100]"
        :page-size="pageSize"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
      />
    </el-footer>
  </el-container>
</template>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
上次更新: 2023/09/17, 20:06:58
Vue 放弃繁琐的render函数,拥抱JSX
倒计时验证

← Vue 放弃繁琐的render函数,拥抱JSX 倒计时验证→

最近更新
01
vim日常使用记录
04-02
02
滑动窗口最大值
04-02
03
有效的字母异位词
04-02
更多文章>
Theme by Vdoing | Copyright © 2021-2025 izhaong | github | 蜀ICP备2021031194号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式