├── static
└── .keep
├── config
├── prod.env.js
├── test.env.js
├── dev.env.js
└── index.js
├── src
├── assets
│ └── logo.png
├── main.js
├── components
│ └── EditableCell.vue
└── App.vue
├── index.html
├── README.md
└── package.json
/static/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/config/prod.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | module.exports = {
3 | NODE_ENV: '"production"'
4 | }
5 |
--------------------------------------------------------------------------------
/src/assets/logo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/heianxing/editable-table-component-vue-element/HEAD/src/assets/logo.png
--------------------------------------------------------------------------------
/config/test.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const merge = require('webpack-merge')
3 | const devEnv = require('./dev.env')
4 |
5 | module.exports = merge(devEnv, {
6 | NODE_ENV: '"testing"'
7 | })
8 |
--------------------------------------------------------------------------------
/config/dev.env.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | const merge = require('webpack-merge')
3 | const prodEnv = require('./prod.env')
4 |
5 | module.exports = merge(prodEnv, {
6 | NODE_ENV: '"development"'
7 | })
8 |
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | CodeSandbox Vue
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # editable-table-component-vue-element
2 | 优雅的elementUI table 单元格可编辑实现方法
3 |
4 | 最近在做可编辑特定列的单元格的elementUI table,看了N多的开源、文章,找到一个很优雅的实现方式,分享给大家。 PS:单元格可编辑的table,用英文搜索:Inline editable table with ElementUI 会得到高质量结果。
5 |
6 | https://codesandbox.io/s/mrqqz43yx
7 |
8 | 英文文章:https://www.reddit.com/r/vuejs/comments/842g5c/inline_editable_table_with_elementui/
9 |
--------------------------------------------------------------------------------
/src/main.js:
--------------------------------------------------------------------------------
1 | // The Vue build version to load with the `import` command
2 | // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
3 | import Vue from "vue";
4 | import App from "./App";
5 | import ElementUI from "element-ui";
6 | import locale from "element-ui/lib/locale/lang/en";
7 | import "element-ui/lib/theme-chalk/index.css";
8 |
9 | Vue.use(ElementUI, { locale });
10 | Vue.use(ElementUI);
11 | Vue.config.productionTip = false;
12 |
13 | /* eslint-disable no-new */
14 | new Vue({
15 | el: "#app",
16 | components: { App },
17 | template: ""
18 | });
19 |
--------------------------------------------------------------------------------
/src/components/EditableCell.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
7 |
8 |
9 |
10 |
11 |
12 |
20 |
21 |
22 |
23 |
24 |
98 |
101 |
--------------------------------------------------------------------------------
/config/index.js:
--------------------------------------------------------------------------------
1 | 'use strict'
2 | // Template version: 1.3.1
3 | // see http://vuejs-templates.github.io/webpack for documentation.
4 |
5 | const path = require('path')
6 |
7 | module.exports = {
8 | dev: {
9 |
10 | // Paths
11 | assetsSubDirectory: 'static',
12 | assetsPublicPath: '/',
13 | proxyTable: {},
14 |
15 | // Various Dev Server settings
16 | host: 'localhost', // can be overwritten by process.env.HOST
17 | port: 8080, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
18 | autoOpenBrowser: false,
19 | errorOverlay: true,
20 | notifyOnErrors: true,
21 | poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-
22 |
23 | // Use Eslint Loader?
24 | // If true, your code will be linted during bundling and
25 | // linting errors and warnings will be shown in the console.
26 | useEslint: true,
27 | // If true, eslint errors and warnings will also be shown in the error overlay
28 | // in the browser.
29 | showEslintErrorsInOverlay: false,
30 |
31 | /**
32 | * Source Maps
33 | */
34 |
35 | // https://webpack.js.org/configuration/devtool/#development
36 | devtool: 'cheap-module-eval-source-map',
37 |
38 | // If you have problems debugging vue-files in devtools,
39 | // set this to false - it *may* help
40 | // https://vue-loader.vuejs.org/en/options.html#cachebusting
41 | cacheBusting: true,
42 |
43 | cssSourceMap: true
44 | },
45 |
46 | build: {
47 | // Template for index.html
48 | index: path.resolve(__dirname, '../dist/index.html'),
49 |
50 | // Paths
51 | assetsRoot: path.resolve(__dirname, '../dist'),
52 | assetsSubDirectory: 'static',
53 | assetsPublicPath: '/',
54 |
55 | /**
56 | * Source Maps
57 | */
58 |
59 | productionSourceMap: true,
60 | // https://webpack.js.org/configuration/devtool/#production
61 | devtool: '#source-map',
62 |
63 | // Gzip off by default as many popular static hosts such as
64 | // Surge or Netlify already gzip all static assets for you.
65 | // Before setting to `true`, make sure to:
66 | // npm install --save-dev compression-webpack-plugin
67 | productionGzip: false,
68 | productionGzipExtensions: ['js', 'css'],
69 |
70 | // Run the build command with an extra argument to
71 | // View the bundle analyzer report after build finishes:
72 | // `npm run build --report`
73 | // Set to `true` or `false` to always turn it on or off
74 | bundleAnalyzerReport: process.env.npm_config_report
75 | }
76 | }
77 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "editable-table-component",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "src/main.js",
6 | "private": true,
7 | "scripts": {
8 | "dev":
9 | "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
10 | "start": "npm run dev",
11 | "unit": "jest --config test/unit/jest.conf.js --coverage",
12 | "test": "npm run unit",
13 | "lint": "eslint --ext .js,.vue src test/unit",
14 | "build": "node build/build.js"
15 | },
16 | "dependencies": {
17 | "element-ui": "2.2.1",
18 | "vue": "^2.5.2"
19 | },
20 | "devDependencies": {
21 | "autoprefixer": "^7.1.2",
22 | "babel-core": "^6.22.1",
23 | "babel-eslint": "^8.2.1",
24 | "babel-helper-vue-jsx-merge-props": "^2.0.3",
25 | "babel-jest": "^21.0.2",
26 | "babel-loader": "^7.1.1",
27 | "babel-plugin-dynamic-import-node": "^1.2.0",
28 | "babel-plugin-syntax-jsx": "^6.18.0",
29 | "babel-plugin-transform-es2015-modules-commonjs": "^6.26.0",
30 | "babel-plugin-transform-runtime": "^6.22.0",
31 | "babel-plugin-transform-vue-jsx": "^3.5.0",
32 | "babel-preset-env": "^1.3.2",
33 | "babel-preset-stage-2": "^6.22.0",
34 | "chalk": "^2.0.1",
35 | "copy-webpack-plugin": "^4.0.1",
36 | "css-loader": "^0.28.0",
37 | "eslint": "^4.15.0",
38 | "eslint-config-airbnb-base": "^11.3.0",
39 | "eslint-friendly-formatter": "^3.0.0",
40 | "eslint-import-resolver-webpack": "^0.8.3",
41 | "eslint-loader": "^1.7.1",
42 | "eslint-plugin-import": "^2.7.0",
43 | "eslint-plugin-vue": "^4.0.0",
44 | "extract-text-webpack-plugin": "^3.0.0",
45 | "file-loader": "^1.1.4",
46 | "friendly-errors-webpack-plugin": "^1.6.1",
47 | "html-webpack-plugin": "^2.30.1",
48 | "jest": "^22.0.4",
49 | "jest-serializer-vue": "^0.3.0",
50 | "node-notifier": "^5.1.2",
51 | "optimize-css-assets-webpack-plugin": "^3.2.0",
52 | "ora": "^1.2.0",
53 | "portfinder": "^1.0.13",
54 | "postcss-import": "^11.0.0",
55 | "postcss-loader": "^2.0.8",
56 | "postcss-url": "^7.2.1",
57 | "rimraf": "^2.6.0",
58 | "semver": "^5.3.0",
59 | "shelljs": "^0.7.6",
60 | "uglifyjs-webpack-plugin": "^1.1.1",
61 | "url-loader": "^0.5.8",
62 | "vue-jest": "^1.0.2",
63 | "vue-loader": "^13.3.0",
64 | "vue-style-loader": "^3.0.1",
65 | "vue-template-compiler": "^2.5.2",
66 | "webpack": "^3.6.0",
67 | "webpack-bundle-analyzer": "^2.9.0",
68 | "webpack-dev-server": "^2.9.1",
69 | "webpack-merge": "^4.1.0"
70 | },
71 | "engines": {
72 | "node": ">= 6.0.0",
73 | "npm": ">= 3.0.0"
74 | },
75 | "browserslist": ["> 1%", "last 2 versions", "not ie <= 8"],
76 | "keywords": []
77 | }
78 |
--------------------------------------------------------------------------------
/src/App.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
9 |
10 |
13 |
14 |
16 |
17 |
19 |
20 |
21 |
22 |
23 |
24 |
27 |
28 | {{row.name}}
29 |
30 |
31 |
32 |
35 |
36 |
42 |
43 |
46 | {{row.gender === 'M' ? 'Male': 'Female'}}
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
61 |
68 | {{row.date}}
69 |
70 |
71 |
72 |
73 |
74 |
75 |
127 |
128 |
134 |
--------------------------------------------------------------------------------