btea

Results 424 comments of btea

I used this [repository](https://github.com/pure-admin/vue-pure-admin) to test the packaged code, and some ts errors occurred. I'm not sure whether it was caused by the modification here or the problem with the...

Don't worry, deal with it when you have time.

@makedopamine Thank you for your quick reply and detailed explanation. 👍

原因如 @zhuminghuan 所说。要避免这种情况,可以给`dropdown` 设置 `:hide-on-click="false"`。[示例](https://element-plus.run/#{"App.vue":"<template>\n  <div>\n    <el-dropdown style=\"margin-left: 8px\" v-if=\"multipleSelection.length>0\" trigger=\"click\" placement=\"bottom\">\n      <el-button>\n        批量操作\n        <el-icon class=\"el-icon--right\"><arrow-down /></el-icon>\n      </el-button>\n      <template #dropdown>\n        <el-dropdown-menu>\n          <el-dropdown-item>\n            <el-popconfirm title=\"确认批量删除信息吗?\">\n              <template #reference>\n                <div style=\"display: flex;align-items: center;\">\n                  <el-icon size=\"15\">\n                    <Delete/>\n                  </el-icon>\n                  删除\n                </div>\n              </template>\n            </el-popconfirm>\n          </el-dropdown-item>\n          <el-dropdown-item>\n            <div>提交维修单</div>\n          </el-dropdown-item>\n        </el-dropdown-menu>\n      </template>\n    </el-dropdown>\n    <el-table :data=\"faultData\" style=\"width: 100%\" @selection-change=\"handleSelectionChange\">\n      <el-table-column type=\"selection\" width=\"55\" />\n      <el-table-column\n          ref=\"table\"\n          v-for=\"item in columns\"\n          :key=\"item.prop\"\n          :fixed=\"item.fixed\"\n          :align=\"item.align\"\n          :prop=\"item.prop\"\n          :min-width=\"item.minWidth\"\n          :width=\"item.width\"\n          :show-overflow-tooltip=\"item.tooltip\"\n          :resizable=\"item.resizable\"\n          :label=\"item.label\"\n      >\n      </el-table-column>\n\n      <el-table-column fixed=\"right\" label=\"操作\" width=\"200\">\n        <template #default=\"scope\">\n          <el-button\n              link\n              type=\"primary\"\n          >\n            详情\n          </el-button>\n          <el-divider direction=\"vertical\" />\n          <el-popconfirm :title='\"确认删除该数据吗?\"' width=\"auto\" @confirm=\"console.info(scope.row.productType)\">\n            <template #reference>\n              <el-button link type=\"danger\">\n                删除\n              </el-button>\n            </template>\n          </el-popconfirm>\n          <el-divider direction=\"vertical\" />\n          <el-dropdown trigger=\"click\" placement=\"bottom\">\n            <el-button link type=\"primary\">\n              更多\n              <el-icon class=\"el-icon--right\"><arrow-down /></el-icon>\n            </el-button>\n            <template #dropdown>\n              <el-dropdown-menu>\n                <el-dropdown-item>\n                  <div>数据监控</div>\n                </el-dropdown-item>\n              </el-dropdown-menu>\n            </template>\n          </el-dropdown>\n        </template>\n      </el-table-column>\n    </el-table>\n    <el-table :data=\"faultData\" style=\"width: 100%\" @selection-change=\"handleSelectionChange\">\n      <el-table-column type=\"selection\" width=\"55\" />\n      <el-table-column\n          ref=\"table\"\n          v-for=\"item in columns\"\n          :key=\"item.prop\"\n          :fixed=\"item.fixed\"\n          :align=\"item.align\"\n          :prop=\"item.prop\"\n          :min-width=\"item.minWidth\"\n          :width=\"item.width\"\n          :show-overflow-tooltip=\"item.tooltip\"\n          :resizable=\"item.resizable\"\n          :label=\"item.label\"\n      >\n      </el-table-column>\n\n      <el-table-column fixed=\"right\" label=\"操作\" width=\"200\">\n        <template #default=\"scope\">\n          <el-button\n              link\n              type=\"primary\"\n          >\n            详情\n          </el-button>\n          <el-divider direction=\"vertical\" />\n          <el-dropdown trigger=\"click\" placement=\"bottom\" :hide-on-click=\"false\">\n            <el-button link type=\"primary\">\n              更多\n              <el-icon class=\"el-icon--right\"><arrow-down /></el-icon>\n            </el-button>\n            <template #dropdown>\n              <el-dropdown-menu>\n                <el-dropdown-item>\n                  <el-popconfirm title=\"确认删除该数据吗?\" @confirm=\"console.info(scope.row.productType)\">\n                    <template #reference>\n                      <el-button link type=\"danger\">\n                        删除\n                      </el-button>\n                    </template>\n                  </el-popconfirm>\n                </el-dropdown-item>\n                <el-dropdown-item>\n                  <div>数据监控</div>\n                </el-dropdown-item>\n              </el-dropdown-menu>\n            </template>\n          </el-dropdown>\n        </template>\n      </el-table-column>\n    </el-table>\n  </div>\n</template>\n\n<script setup>\nimport {onMounted, reactive, ref} from \"vue\";\nimport {ArrowDown, Delete} from \"@element-plus/icons-vue\";\n  const columns=[{\n  \"prop\": \"productType\",\n  \"label\": \"产品型号\",\n  \"width\": \"120\",\n}\n]\nlet multipleSelection = ref([])\nlet faultData=[{\n  productType:\"MD30\"\n}]\n\nconst handleSelectionChange=(rows)=>{\n  multipleSelection.value=rows\n}\n</script>","import-map.json":"{\n  \"imports\": {\n    \"vue\": \"https://fastly.jsdelivr.net/npm/@vue/runtime-dom@latest/dist/runtime-dom.esm-browser.js\",\n    \"@vue/shared\": \"https://fastly.jsdelivr.net/npm/@vue/shared@latest/dist/shared.esm-bundler.js\",\n    \"element-plus\": \"https://fastly.jsdelivr.net/npm/element-plus@latest/dist/index.full.min.mjs\",\n    \"element-plus/\": \"https://fastly.jsdelivr.net/npm/element-plus@latest/\",\n    \"@element-plus/icons-vue\": \"https://fastly.jsdelivr.net/npm/@element-plus/icons-vue@2/dist/index.min.js\"\n  },\n  \"scopes\": {}\n}","element-plus.js":"import { getCurrentInstance } from 'vue'\nimport ElementPlus from 'element-plus'\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://fastly.jsdelivr.net/npm/element-plus@latest/dist/index.css', 'https://fastly.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.all(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","_o":{}})

Indeed, we should change the `engine` field to `>=18.0.0`.

> This is basically a duplicate of #420; though I'm open to reconsidering the decision there. > Oh, sorry, I didn't notice this. > Can you elaborate more on the...

> I'm especially hesitant to add it as it's trivial to implement wherever it's needed; the code is literally: > > ```js > !(await fs.readdir(dir)).length > ``` > Yes, the...

There should be no error in the currently dependent ts version. You can try switching the ts version in the lower right corner.

@long4488296 `el-pagination` 只支持通过 `small` 为 `true` 或 `false` 来设置小尺寸和标准尺寸,你的写法应该没问题。