Cui yunlong

Results 9 comments of Cui yunlong

![Image](https://github.com/user-attachments/assets/9753c8da-1b88-4993-8e99-7c22f4e86249) ![Image](https://github.com/user-attachments/assets/e0b3f556-231b-4ed0-92d4-c588623f5494)

> 使用你的代码没有复现出来 请重复多次(20次以上) ![Image](https://github.com/user-attachments/assets/940030f1-9a80-4246-94b5-9bca618c3238)

> [@cylgdzz111](https://github.com/cylgdzz111) 请提供下Chrome的版本 134.0.6998.44(正式版本) (arm64) 这是我的版本

> [@SpanManX](https://github.com/SpanManX) detached event是detached node引起的。 > > 我在Chrome版本134.0.6998.89(Stable)复现了该问题。经排查detached node不能被回收的条件是:在DevTools打开的情况下触发了CSS Transition。 [@cylgdzz111](https://github.com/cylgdzz111) 提供的步骤里是触发了单元格的CSS Transition。 > > 针对上面的排查结果,我已向Chromium提交了issue, Chromium团队已在跟进,请查看https://issues.chromium.org/issues/401814682 我这边看到的是 addEventListener导致的泄漏,我本地修复后 内存显著下降了

> Hi, thanks for your contribution. > > Could you provide an example with details of the specific problem before and after the modification? ## Problem Before Modification Before the...

![image](https://github.com/user-attachments/assets/7bfe5a81-38b0-4eff-a9fb-c841ace4e592)

> The screenshots you took seem to use `element-ui`? Can you provide a link to reproduce it? Sorry, I used the wrong picture Use element-plus official website:https://element-plus.org/zh-CN/component/table.html Switch back and...

> playground [复现地址](https://element-plus.run/#{"App.vue":"<script setup lang=\"ts\">\nimport { ref } from 'vue'\nimport { ElButton } from 'element-plus'\n\nconst showTable1 = ref(true)\n\n\nconst tableData1 = ref([\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n  { date: '2024-01-01', name: '张三', address: '北京市朝阳区' },\n])\n\nconst tableData2 = ref([\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  { date: '2024-02-01', name: '赵六', address: '深圳市南山区' },\n  \n])\n</script>\n\n<template>\n <el-button type=\"primary\" @click=\"showTable1 = !showTable1\" style=\"margin-bottom: 16px\">\n    {{ showTable1 ? '切换到表格 2' : '切换到表格 1' }}\n  </el-button>\n\n\n  <el-table\n    v-if=\"showTable1\"\n    :data=\"tableData1\"\n    style=\"width: 100%\"\n    border\n  >\n    <el-table-column prop=\"date\" label=\"日期\" width=\"180\" />\n    <el-table-column prop=\"name\" label=\"姓名\" width=\"180\" />\n    <el-table-column prop=\"address\" label=\"地址\" />\n  </el-table>\n\n  <el-table\n    v-else\n    :data=\"tableData2\"\n    style=\"width: 100%\"\n    border\n  >\n    <el-table-column prop=\"date\" label=\"日期\" width=\"180\" />\n    <el-table-column prop=\"name\" label=\"姓名\" width=\"180\" />\n    <el-table-column prop=\"address\" label=\"地址\" />\n  </el-table>\n</template>\n","element-plus.js":"import ElementPlus from 'element-plus'\nimport { getCurrentInstance } from 'vue'\n\nlet installed = false\nawait loadStyle()\n\nexport function setupElementPlus() {\n  if (installed) return\n  const instance = getCurrentInstance()\n  instance.appContext.app.use(ElementPlus)\n  installed = true\n}\n\nexport function loadStyle() {\n  const styles = ['https://cdn.jsdelivr.net/npm/element-plus@latest/dist/index.css', 'https://cdn.jsdelivr.net/npm/element-plus@latest/theme-chalk/dark/css-vars.css'].map((style) => {\n    return new Promise((resolve, reject) => {\n      const link = document.createElement('link')\n      link.rel = 'stylesheet'\n      link.href = style\n      link.addEventListener('load', resolve)\n      link.addEventListener('error', reject)\n      document.body.append(link)\n    })\n  })\n  return Promise.allSettled(styles)\n}\n","tsconfig.json":"{\n  \"compilerOptions\": {\n    \"target\": \"ESNext\",\n    \"jsx\": \"preserve\",\n    \"module\": \"ESNext\",\n    \"moduleResolution\": \"Bundler\",\n    \"types\": [\"element-plus/global.d.ts\"],\n    \"allowImportingTsExtensions\": true,\n    \"allowJs\": true,\n    \"checkJs\": true\n  },\n  \"vueCompilerOptions\": {\n    \"target\": 3.3\n  }\n}\n","PlaygroundMain.vue":"<script setup>\nimport App from './App.vue'\nimport { setupElementPlus } from './element-plus.js'\nsetupElementPlus()\n</script>\n\n<template>\n  <App />\n</template>\n","import-map.json":"{\n  \"imports\": {\n    \"vue\": \"https://cdn.jsdelivr.net/npm/@vue/runtime-dom@latest/dist/runtime-dom.esm-browser.js\",\n    \"@vue/shared\": \"https://cdn.jsdelivr.net/npm/@vue/shared@latest/dist/shared.esm-bundler.js\",\n    \"element-plus\": \"https://cdn.jsdelivr.net/npm/element-plus@latest/dist/index.full.min.mjs\",\n    \"element-plus/\": \"https://cdn.jsdelivr.net/npm/element-plus@latest/\",\n    \"@element-plus/icons-vue\": \"https://cdn.jsdelivr.net/npm/@element-plus/icons-vue@2/dist/index.min.js\"\n  },\n  \"scopes\": {}\n}","_o":{}}) 第一步:点击切换到表格2按钮 第二步:点击表格任意一点 第三部:点击切换到表格1按钮 重复上述操作,可以观察到内存不断上涨 且不可回收