无法在 Vuejs 中访问 ag-Grid API
Cannot access ag-Grid API in Vuejs
我在 ag-grid 网站上做简单的 "Get Started with ag-Grid in Your Vue Project",运行 遇到了问题。在教程的某个步骤中,它尝试使用 ag-grid-vue 上的 gridReady 属性来执行一个名为 onGridReady 的函数。但这似乎永远不会火。
我完全按照此处所述的说明进行操作:https://www.ag-grid.com/vue-getting-started/?utm_source=ag-grid-readme&utm_medium=repository&utm_campaign=github
App.vue:
<template>
<div>
<button @click="getSelectedRows()">Get Selected Rows</button>
<ag-grid-vue style="width: 500px; height: 500px;"
class="ag-theme-balham"
:columnDefs="columnDefs"
:rowData="rowData"
rowSelection="multiple"
:gridReady="onGridReady">
</ag-grid-vue>
</div>
</template>
<script>
import {AgGridVue} from "ag-grid-vue";
export default {
name: 'App',
data() {
return {
columnDefs: null,
rowData: null
}
},
components: {
AgGridVue
},
watch: {
onGridReady: {
handler: function (params) {
alert('eeeee')
},
deep: true
}
},
methods: {
onGridReady(params) {
this.gridApi = params.api;
this.columnApi = params.columnApi;
alert('TEST')
},
getSelectedRows() {
const selectedNodes = this.gridApi.getSelectedNodes();
const selectedData = selectedNodes.map( node => node.data );
const selectedDataStringPresentation = selectedData.map( node => node.make + ' ' + node.model).join(', ');
alert(`Selected nodes: ${selectedDataStringPresentation}`);
}
},
beforeMount() {
this.columnDefs = [
{headerName: 'Make', field: 'make', checkboxSelection: true},
{headerName: 'Model', field: 'model'},
{headerName: 'Price', field: 'price'}
];
fetch('https://api.myjson.com/bins/15psn9')
.then(result => result.json())
.then(rowData => this.rowData = rowData);
}
}
</script>
<style lang="scss">
@import "~ag-grid-community/dist/styles/ag-grid.css";
@import "~ag-grid-community/dist/styles/ag-theme-balham.css";
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
我希望能够单击按钮并查看所选节点并发出警报。
得到的是错误信息:
未捕获的类型错误:无法读取未定义的 属性 'getSelectedNodes'
在 VueComponent.getSelectedRows (VM2832 App.vue:54)
改用它来绑定事件(在 Vue 中):
@gridReady="onGridReady"
参见:
我在 ag-grid 网站上做简单的 "Get Started with ag-Grid in Your Vue Project",运行 遇到了问题。在教程的某个步骤中,它尝试使用 ag-grid-vue 上的 gridReady 属性来执行一个名为 onGridReady 的函数。但这似乎永远不会火。
我完全按照此处所述的说明进行操作:https://www.ag-grid.com/vue-getting-started/?utm_source=ag-grid-readme&utm_medium=repository&utm_campaign=github
App.vue:
<template>
<div>
<button @click="getSelectedRows()">Get Selected Rows</button>
<ag-grid-vue style="width: 500px; height: 500px;"
class="ag-theme-balham"
:columnDefs="columnDefs"
:rowData="rowData"
rowSelection="multiple"
:gridReady="onGridReady">
</ag-grid-vue>
</div>
</template>
<script>
import {AgGridVue} from "ag-grid-vue";
export default {
name: 'App',
data() {
return {
columnDefs: null,
rowData: null
}
},
components: {
AgGridVue
},
watch: {
onGridReady: {
handler: function (params) {
alert('eeeee')
},
deep: true
}
},
methods: {
onGridReady(params) {
this.gridApi = params.api;
this.columnApi = params.columnApi;
alert('TEST')
},
getSelectedRows() {
const selectedNodes = this.gridApi.getSelectedNodes();
const selectedData = selectedNodes.map( node => node.data );
const selectedDataStringPresentation = selectedData.map( node => node.make + ' ' + node.model).join(', ');
alert(`Selected nodes: ${selectedDataStringPresentation}`);
}
},
beforeMount() {
this.columnDefs = [
{headerName: 'Make', field: 'make', checkboxSelection: true},
{headerName: 'Model', field: 'model'},
{headerName: 'Price', field: 'price'}
];
fetch('https://api.myjson.com/bins/15psn9')
.then(result => result.json())
.then(rowData => this.rowData = rowData);
}
}
</script>
<style lang="scss">
@import "~ag-grid-community/dist/styles/ag-grid.css";
@import "~ag-grid-community/dist/styles/ag-theme-balham.css";
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
我希望能够单击按钮并查看所选节点并发出警报。 得到的是错误信息: 未捕获的类型错误:无法读取未定义的 属性 'getSelectedNodes' 在 VueComponent.getSelectedRows (VM2832 App.vue:54)
改用它来绑定事件(在 Vue 中):
@gridReady="onGridReady"
参见: