Extjs之两个JS页面直接的对象传递问题

Extjs之两个JS页面直接的对象传递问题,第1张

同一页面的JS上下文是相同作用域的,

你的应该是不同页面间传值、所以借用了cookies;

//接收页面:

var record=ExtutilCookiesget("valueJson");

//然后 拿个record列名自己看看

var obj=Extdecode(record);

alert(objcolName);

extjs的树形结构本身就会很慢,3000个节点也绝对是致命的,如果一起加载很可能会出现页面请求超时,所以我们的项目中用到这种比较大的树一般不会选择用extjs本身的树形结构,一般会选用比较轻量级的框架,比如zTree,他能跟extjs很好的结合,有能力可以改改css,这样跟extjs的主题会更加和谐,zTree使用简单,速度不只是extjs treepanel的几倍,可异步加载,也可直接加载,个添加各种事件,你值得拥有

在基于extjs的MVC开发的时候用到命名空间,也成为应用的名称,是一个全局变量,在extjs加载时识别本项目用到的文件并找到相应的类;extjs MVC结构如下所示:

extjs MVC项目的命名规则是:命名空间名+包名+js文件名

假设一个项目的命名空间为name:'crm'在view下有一个自定义类addForm,那么根据如上规则该类就定义为Extdefine('crmviewaddForm',{});那么extjs在加载时就会在crm这个命名空间找到view,再找到view下的addForm这个类;

首先,无论哪种方式,都需要model和store,其次,这两种方法都可以,一般采用第一种,比较方便,只需要通过storeload()加载数据即可,而且无需自己解析返回值,第二种方法可以用于一次返回多个组件的data,或者需要返回除组件data之外的值,然后解析之后通过各个组件的storeloadData(data)来加载数据

ExtJs Grid分页时,默认情况下每页的序号都是从1起始的,这往往不符合我们的习惯。这里实现了序 号的自动增加。

实现步骤如下:

1、定义全局变量。

var record_start = 0;

2、Grid的columns部分的定义。

columns : [new ExtgridRowNumberer({

header : "序号",

width : 40,

renderer:function(value,metadata,record,rowIndex){

  return record_start + 1 + rowIndex;

}

  }), {

header : "项目编号",

width : 50,

sortable : false,

dataIndex : "projectNumber"

  }]

3、Grid 的PagingToolbar部分的定义。

bbar : new ExtPagingToolbar({

store : grid_store,

pageSize : 8,

displayInfo : true,

beforePageText:"第",

afterPageText:"/ {0}页",

firstText:"首页",

prevText:"上一页",

nextText:"下一页",

lastText:"尾页",

refreshText:"刷新",

displayMsg : "当前显示记录从 {0} - {1} 总 {2} 条记录",

emptyMsg : "没有相关记录!",

doLoad : function(start){

  record_start = start;

var o = {}, pn = thisparamNames;

o[pnstart] = start;

o[pnlimit] = thispageSize;

thisstoreload({params:o});

  }

  })

说明:

1、全局变量record_start用于记录列表开始的数据点,如第一页,那么为0,如第二页,那么为8,这 里分页pagesize设置为了8

2、分页中doLoad这部分的代码来自于ExtPagingToolbar的doLoad方法,PagingToolbar在分页发生变 化时会调用这个方法来重新load数据,只是多了个对全局变量进行赋值的步骤,为的就是在分页发生变化 时,记录传递给Url的参数start的值。

3、在columns中实例化ExtgridRowNumberer时,重写了renderer方法,其实之所以这样做的原因,大家看一下 ExtgridRowNumberer源码中的renderer方法就知道了,就是根据行号+1来设置序号的,这里我们改这个方法,是为了得到行号+分页变化时得到的start参数的值+1 的值,这样就能够正确得到序号结合分页的数据了。

以上就是关于Extjs之两个JS页面直接的对象传递问题全部的内容,包括:Extjs之两个JS页面直接的对象传递问题、Extjs 同步树treepanel,如何提高加载速度只加载根节点数据,展开节点后再加载节点下数据。、extjs中命名空间是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9687151.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存