[Phonegap+Sencha Touch] 移动开发8、store和proxy

2024-01-28 11:58

本文主要是介绍[Phonegap+Sencha Touch] 移动开发8、store和proxy,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上图是一个支持服务端分页、服务端排序、和服务端过滤的一个store的配置。

一、store
常用的配置参数:
1、autoLoad:Boolean, 表示创建store之后是否立即加载数据,默认false。
因为我们要等到view显示的时候,手动去调用store.load()方法,加载数据

2、autoSync:Boolean, 对store数据的变更(增删改查),是否立即保存,默认false

3、sorters:Array, 排序规则的集合,是一个数组,可以有多个(数组里的每个元素最后都被转换成了Ext.util.Sorter的实例)。写法如:
        sorters: [{
            property: "RequestDate",
            direction: "DESC"
        }]
        或者
        sorters: [Ext.create('Ext.util.Sorter', {
            property: "RequestDate",
            direction: "DESC"
        })]

     Ext.util.Sorter的配置项:
     常用的有
     (1) property:String, 排序的字段;
     (2) direction:String, 排序方向,可选值'ASC', 'DESC';
     还有
     (3) id:为每个排序规则指定一个id;
     (4) sorterFn:Function, 特殊指定一个排序的方法,而不按照property指定的字段来排序。比如有个字段OpDateTime,我不想按照property: OpDateTime排序,而想要格式化成'Y-m-d'之后再排序,此时就应该用sorterFn;
     (5) root:String, 意思就是property是来自record的哪里的。默认值是null,也可以配置为'data',也就是默认排序的字段是record.data里面的;

4、groupField:String, 分组的字段

5、groupDir:String, 分组之间的排序方向,'ASC'(默认)或'DESC'

6、grouper:Object, 即分组排序。
     使用分组功能,需要把用到这个store的dataview控件的grouped设为true。grouper 和 groupField & groupDir 只需要指定一种
     (grouper这个配置最后被转换成为Ext.util.Grouper的实例)     
     Ext.util.Grouper继承自Ext.util.Sorter。所以,grouper也是一个sorter,grouper有sorter的属性。
     (1) property:String, 分组的字段,是分组的依据;
     (2) direction:String, 分组之间的排序方向(组与组之间的,而不是组里内容之间的),可选值'ASC', 'DESC';
还有
     (3) groupFn:Function, 分组的依据。这个配置和property只需要指定一个
          groupFn是一个方法,返回值用于分组(用于property不能满足分组的时候,比如有个字段OpDateTime,我不想按照property: OpDateTime分组,而想要格式化成'Y-m-d'之后再分组,此时就应该用groupFn)
     (4) sortProperty:String, 分组之间的排序依据,一般和property设置成一样字段(我测试过不一样的时候,会出现分组乱了的现象),如果property没有设置,而是设置了groupFn,那么最好是设成groupFn里面用到的字段,或者根据情况设置。

7、pageSize:Int, store分页的每页记录数,默认25
     请求后台数据的参数像这样:?page=1&start=0&limit=25
     start是根据page和limit计算出来的,其实page和start只要其中一个就够了。

8、params:Object, 需要传递到后台的其他参数。默认值{},这个params会给proxy,由proxy去请求数据

9、remoteGroup:Bollean,默认false。如果设置成true,
     请求后台数据的参数像这样:?page=1&start=0&limit=25&group=[{"property":"OpDate","direction":"ASC"}]

10、remoteSort:Bollean,默认false。如果设置成true,
     请求后台数据的参数像这样:?page=1&start=0&limit=25&group=[{"property":"OpDate","direction":"ASC"}]&sort=[{"property":"OpDate","direction":"ASC"}, {"property":"ObjType","direction":"ASC"}]
     注意:
     (1) 如果有store设置了grouper,那么会把grouper指定的字段和方向,作为sort里的第一个元素。
          grouper的property如果没有指定(而是指定了groupFn),那么group和sort的第一个元素会是这样的:{"property":null,"direction":"ASC"}
     (2) 如果proxy的simpleSortMode设置为了true,那么只会传递一个sort规则,例如:?page=1&start=0&limit=25&sort=OpDate&dir=ASC

11、remoteFilter:Bollean,默认false。如果设置成true,
     请求后台数据的参数像这样:?page=1&start=0&limit=25&filter=[{"property":"UserName","value":"Admin"},{"property":"ObjName","value":"采购订单"}]

二、proxy
proxy有很多类型,type配置的可选值有ajax, direct, jsonp, rest, localStorage, sessionStorage, sql等
ajax算是前4种的基础了,用的也比较多。最后3种是本地存储。
通过给ajax配置api属性、或者使用direct、rest可以很方便实现简单的增删改查(CRUD,Create, Retrieve, Update, Delete)。
实际使用中一般通过ajax获取数据,增删改还是手动控制的多。
顶上的图,就是配置的ajax获取数据。
看看主要的配置项:
1、type:String,指定proxy的类型

2、actionMethods:Object,包含create、read、update和destroy四种action,每种action可选值'GET', 'POST',即Http请求的类型,也就是上面说的?page=1&start=0&limit=25是如何传递到后台的。
'GET'就是说page=1&start=0&limit=25拼接到url的后面,'POST'就是post提交
     actionMethods: {
          create: "POST",
          read: "GET",
          update: "POST",     
          destroy: "POST",    
     }

3、simpleSortMode:Boolean,上面的store讲过了

4、extraParams:Object, 需要传递到后台的其他参数。

5、filterParam:String,默认'filter'

6、groupParam:String,默认'group'

7、limitParam:String,默认'limit'

8、pageParam:String,默认'page'

9、sortParam:String,默认'sort'

10、startParam:String,默认'start'
上面6个XXXParam,是作为Http请求数据的参数名,默认就行,最好不要改

11、reader:Object,如何读取获取到的数据,有下面的配置项:
     (1) type:String
     (2) rootProperty:String,默认''。分页的时候可以指定此属性,不分页的时候默认空字符串就行。
     (3) successProperty:String,默认'success'。表示返回数据是否有错误,不是必须的
     (4) totalProperty:String,默认'total'。分页的时候,服务端除了返回当前页的数据,还要返回所有页的数据总条数
     reader: {          
          type: "json",          
          rootProperty: 'root'
     }
向上面这个,说明后台返回的数据是json类型,而且返回的数据类似 {total: 100, root: [{name: 'one'}, {name: 'two'}, {name: 'three'}, {name: 'four'}]}
即total是数据总数,root是当前页的所有数据

12、url:String,请求数据的url来源

这篇关于[Phonegap+Sencha Touch] 移动开发8、store和proxy的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653575

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3