Vue 表格中的text按钮被点击后,弹出备注框 + sessionStorage

html 复制代码
<template>
  <div>
    <el-table :data="tableData" border style="width: 100%" :cell-style="{ textAlign: 'center' }"
            :header-cell-style="{ textAlign: 'center' }" >
      <el-table-column prop="date" label="日期" :min-width="100"></el-table-column>
      <el-table-column prop="name" label="姓名"></el-table-column>
      <el-table-column prop="id" label="品类ID"></el-table-column>
      <el-table-column prop="type" label="提醒周期" :formatter="formatAlertType"></el-table-column>
      <el-table-column prop="remark" label="备注">
        <template slot-scope="scope">
          <el-button @click="showRemarkDialog(scope.row)" type="text" icon="el-icon-s-comment">备注</el-button>
        </template>
      </el-table-column>
    </el-table>

    <el-dialog :title="title" :visible.sync="dialogVisible" width="420px" class="remark-dialog">
      <div class="dialog-content">
        <span class="remark-label">备注:</span>
        <el-input type="textarea" v-model="remark" placeholder="请输入备注" :rows="5" maxlength="200" show-word-limit
          class="custom-textarea"></el-input>
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取消</el-button>
        <el-button type="primary" @click="submitForm">确定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import '@/styles/textarea.css'
export default {
  data() {
    return {
      tableData: [
        { date: '2024-06-01', id: '01000', type: 0, name: '张三', savedRemark: '' },
        { date: '2024-06-02', id: '01001', type: 1, name: '李四', savedRemark: '' },
        { date: '2024-06-03', id: '01002', type: 0, name: '王五', savedRemark: '' },
      ],
      dialogVisible: false,
      remark: '',
      activeRow: null,

      alertOptions: [
        { label: '一周', value: 0 },
        { label: '一月', value: 1 }
      ],
      title:''
    };
  },
  methods: {
    showRemarkDialog(row) {
      this.remark = row.savedRemark;
      this.activeRow = row;
      this.dialogVisible = true;
      this.title = row.name
    },
    submitForm() {
      if (this.activeRow) {
        this.activeRow.savedRemark = this.remark;
        sessionStorage.setItem(this.getRowKey(this.activeRow), this.remark);
      }
      this.dialogVisible = false;
    },
    getRowKey(row) {
      return `${row.date}_${row.name}_${row.id}`;
    },
    loadSavedRemarks() {
      this.tableData.forEach(row => {
        row.savedRemark = sessionStorage.getItem(this.getRowKey(row)) || '';
      });
    },
    formatAlertType(row, column, cellValue) {
      const alertType = this.alertOptions.find(option => option.value === cellValue);
      return alertType ? alertType.label : '';
    },
  },
  created() {
    this.loadSavedRemarks()
  }
};
</script>

<style scoped>
.remark-dialog {
  margin-top: 10px;
}

.remark-label {
  font-size: 16px;
  margin-bottom: 10px;
  display: block;
}

.dialog-footer {
  text-align: center;
}

.custom-textarea {
  overflow-y: auto;
  resize: vertical;
}
</style>
<style>
.remark-dialog {
  .el-dialog__header {
    border-bottom: none;
  }

  .el-dialog__body {
    padding: 0;
  }

  .dialog-content {
    padding: 0 40px;
  }

  .el-dialog__footer {
    padding: 10px 10px 10px;
    border-top: none;
  }
}
</style>

element-textarea,滚动条样式更美观.

element-textarea,滚动条样式更美观._element的textarea的滚动条怎么修改-CSDN博客文章浏览阅读1.6k次。element-textarea,滚动条样式更美观.element的textarea的滚动条怎么修改https://blog.csdn.net/Backbody/article/details/129422810textarea.css

css 复制代码
@charset "UTF-8";

.el-textarea__inner::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.el-textarea__inner::-webkit-scrollbar-thumb {
  border-radius: 3px;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  background-color: #c3c3c3;
}

.el-textarea__inner::-webkit-scrollbar-track {
  background-color: transparent;
}

参考 element-ui表格内容居中(详细教程element-ui表格内容居中(详细教程)_elementui表格内容居中-CSDN博客

cpp 复制代码
:cell-style="{ textAlign: 'center' }"
:header-cell-style="{ textAlign: 'center' }"
table加这一句就好了

推荐和参看文章:element-plus中el-dialog使用::v-deep()穿透设置样式不生效踩坑记录

element-plus中el-dialog使用::v-deep()穿透设置样式不生效踩坑记录_element-plus样式穿透失败-CSDN博客文章浏览阅读736次。如上:我想去掉插槽自带的下边框和上边框,但是不生效。给el-dialog加个类,在不带scope的。_element-plus样式穿透失败https://blog.csdn.net/jieyucx/article/details/139283454?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-139283454-blog-132542643.235^v43^pc_blog_bottom_relevance_base1&spm=1001.2101.3001.4242.1&utm_relevant_index=1

相关推荐
赵大仁2 分钟前
深入理解 Vue 3 中的具名插槽
前端·javascript·vue.js·react.js·前端框架·ecmascript·html5
一雨方知深秋6 分钟前
v-bind 操作 class(对象,数组),v-bind 操作 style
前端·css·vue.js·html·style·class·v-bind
安晴晚风1 小时前
从0开始在linux服务器上部署SpringBoot和Vue
linux·运维·前端·数据库·后端·运维开发
前端小小王2 小时前
pnpm、Yarn 和 npm 的区别?
前端·npm·node.js
supermapsupport2 小时前
使用npm包的工程如何引入mapboxgl-enhance/maplibre-gl-enhance扩展包
前端·webpack·npm·supermap·mapboxgl
牛奔2 小时前
windows nvm 切换node版本后,npm找不到
前端·windows·npm·node.js
鱼大大博客2 小时前
Edge SCDN酷盾安全重塑高效安全内容分发新生态
前端·安全·edge
鸭梨山大。2 小时前
NPM组件包 vant部分版本内嵌挖矿代码
前端·安全·npm·node.js·vue
蟾宫曲7 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心7 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js