Extjs 项目中常用的小技巧,也许你用得着(5)--设置 Ext.data.Store 传参的请求方式

简介: 1.extjs 给怎么给panel设背景色 设置bodyStyle:'background:#ffc;padding:10px;', var resultsPanel = Ext.create('Ext.

1.extjs 给怎么给panel设背景色

设置bodyStyle:'background:#ffc;padding:10px;',

var resultsPanel = Ext.create('Ext.panel.Panel', {
    title: 'Results',
    width: 600,
    height: 400,
    renderTo: Ext.getBody(),
    bodyStyle: 'background:#ffc; padding:10px;',
    layout: {
        type: 'vbox',       // Arrange child items vertically
        align: 'stretch',    // Each takes up full width
        padding: 5
    },
    items: [{               // Results grid specified as a config object with an xtype of 'grid'
        xtype: 'grid',
        columns: [{header: 'Column One'}],            // One header just for show. There's no data,
        store: Ext.create('Ext.data.ArrayStore', {}), // A dummy empty data store
        flex: 1                                       // Use 1/3 of Container's height (hint to Box layout)
    }, {
        xtype: 'splitter'   // A splitter between the two child items
    }, {                    // Details Panel specified as a config object (no xtype defaults to 'panel').
        title: 'Details',
        bodyPadding: 10,
        items: [{
            fieldLabel: 'Data item',
            xtype: 'textfield'
        }], // An array of form fields
        flex: 2             // Use 2/3 of Container's height (hint to Box layout)
    }]
});

2. Extjs4.0 设置 Ext.data.Store 传参的请求方式

 

var Store = Ext.create('Ext.data.Store', {  
    pageSize: pageSize,  
    model: 'Ext.data.Model名称',  
    autoLoad: false,  
    proxy: {  
        type: 'ajax',  
        url: '请求路径',  
        getMethod: function(){ return 'POST'; },//亮点,设置请求方式,默认为GET  
        reader: {  
            type: 'json',  
            root: 'Data',  
            totalProperty: 'totalCount'  
        }  
    },   
    listeners: {  
        'beforeload': function (store, op, options) {  
            var params = {  
                //参数  
            };  
            Ext.apply(store.proxy.extraParams, params);   
        }  
    }  
});  

 

3.ExtJS grid 带参数查询分页 store 传额外参数解决办法

 

在store的beforeload事件里面重写store.proxy.extraParams,添加新参数

 

就不必每次都手动的添加参数

 

store.on('beforeload', function (store, options) {
        var new_params = { name: Ext.getCmp('search').getValue() };
        Ext.apply(store.proxy.extraParams, new_params);
        // alert('beforeload');
    });
在Extjs3 中的
store.on('beforeload', function () {
            store.baseParams = {
                name: '5555555',
                intss: '666666666'
            };
        }); 

下面给出完整的代码。原理很简单,将搜索条件放在store的baseParams中,每次加载都赋值。

只是需要强制赋值,因为默认的pagetoolbar只会把start、limit、page、sort、dir传递给store

var store = new Ext.data.Store({  
       pageSize: GridPageSize,  
       model: 'Master',  
       autoLoad: false,   
       proxy: {  
           type: 'ajax',  
           url: '/master/GetMasterData',  
           reader: {  
               type: 'json',  
               root: 'data',  
               totalProperty: 'totalCount'  
           }  
       },  
       fields: [  
           { name: 'Id' },  
           { name: 'Master_Name' }  
           
       //排序  
       sorters: [{  
           property: 'Master_Name',  
           direction: 'DESC'  
       }]   
        
   });  
store.on('beforeload', function (store, options) {  
        var new_params = { name: Ext.getCmp('search').getValue() };  
        Ext.apply(store.proxy.extraParams, new_params);  
        // alert('beforeload');  
    });  
store.load({  
       params: { start: 0, limit: GridPageSize }  
   })  

 

 

 

 

目录
相关文章
|
6月前
sd.js 2.0封装:更加简化请求传参内容(逐步废弃、逐渐日落2024.01.02)
sd.js 2.0封装:更加简化请求传参内容(逐步废弃、逐渐日落2024.01.02)
|
3月前
|
JavaScript UED
以 Vue 3 项目为例,多个请求下如何全局封装 Loading 的展示与关闭?其中大有学问!
以 Vue 3 项目为例,多个请求下如何全局封装 Loading 的展示与关闭?其中大有学问!
|
前端开发 JavaScript
前端学习笔记202306学习笔记第三十七天-js中得错误和异常2
前端学习笔记202306学习笔记第三十七天-js中得错误和异常2
64 0
|
6月前
|
移动开发 开发框架 小程序
uni-app的优缺点;uniapp进行条件编译的两种方法;小程序端和H5的代表值
uni-app的优缺点;uniapp进行条件编译的两种方法;小程序端和H5的代表值
229 0
|
JavaScript
动态给vue的data添加一个新的属性时会发生什么?怎样解决?
动态给vue的data添加一个新的属性时会发生什么?怎样解决?
190 1
|
前端开发 JavaScript
前端学习笔记202306学习笔记第三十七天-js中得错误和异常1
前端学习笔记202306学习笔记第三十七天-js中得错误和异常1
41 0
|
前端开发 JavaScript
前端学习笔记202306学习笔记第三十七天-js中得错误和异常3
前端学习笔记202306学习笔记第三十七天-js中得错误和异常3
50 0
|
JavaScript
Vue antdv a-select 自定义 dropdownRender 的内容放到头部
Vue antdv a-select 自定义 dropdownRender 的内容放到头部
1571 0
|
前端开发
优雅草蜻蜓k知识付费系统前端打包报错问题 前端打包报错 文件查找失败:’vue-flip-page’ 文件查找失败:’vue-flip-page’ at pages\read\index.vue:12
优雅草蜻蜓k知识付费系统前端打包报错问题 前端打包报错 文件查找失败:’vue-flip-page’ 文件查找失败:’vue-flip-page’ at pages\read\index.vue:12
优雅草蜻蜓k知识付费系统前端打包报错问题  前端打包报错 文件查找失败:’vue-flip-page’ 文件查找失败:’vue-flip-page’ at pages\read\index.vue:12
|
JavaScript 前端开发
#yyds干货盘点# 【js学习笔记十七】普通函数中的this指向问题解决方案call
#yyds干货盘点# 【js学习笔记十七】普通函数中的this指向问题解决方案call
92 0
#yyds干货盘点# 【js学习笔记十七】普通函数中的this指向问题解决方案call