CN102236673B - 一种基于ajax的资源多页分配方法 - Google Patents
一种基于ajax的资源多页分配方法 Download PDFInfo
- Publication number
- CN102236673B CN102236673B CN 201010164453 CN201010164453A CN102236673B CN 102236673 B CN102236673 B CN 102236673B CN 201010164453 CN201010164453 CN 201010164453 CN 201010164453 A CN201010164453 A CN 201010164453A CN 102236673 B CN102236673 B CN 102236673B
- Authority
- CN
- China
- Prior art keywords
- role
- binding
- resource
- bindingset
- cancellation
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Landscapes
- Information Transfer Between Computers (AREA)
Abstract
本发明公开一种AJAX的资源多页分配方法,其包括以下步骤:步骤S1:对bindingSet进行初始化设置,将其初始集合设为数据库中与资源已绑定的角色主键;步骤S2:用户在前台页面所进行的绑定/取消绑定操作反应到bindingSet的变化;步骤S3:用户进行提交操作,将新集合bindingSet更新到数据库或其他存储实体。本发明通过轻松点击一个按钮或链接,一次性实现将查询到的附合条件的多页角色列表与资源进行绑定/取消绑定操作。
Description
技术领域
本发明涉及利用AJAX(Asynchronous JavaScript and XML)框架进行WEB开发领域,特别涉及一种基于AJAX的资源多页分配方法。
背景技术
在应用系统中,资源与角色的绑定是个普遍的问题。在现有的应用系统中,一般是通过查询获得附合条件的角色列表,选中/取消某个角色对应的复选框,实现对应角色与资源的绑定/取消绑定操作;或者是选中/取消当前页的角色,以实现当前页角色与资源的绑定/取消绑定操作。
如果查询到的角色很多比如成千上万页的情况下,一个一个或者一页一页地将其与资源绑定,就显得异常繁琐。
因此,急需一种方法可将查询到的多页角色一次性全部与资源实现绑定或取消绑定。
AJAX是多种技术的综合,包括Javascript、XHTML和CSS、DOM、XML和XSTL、XMLHttpRequest。它使用XHTML和CSS标准化呈现,使用DOM实现动态显示和交互,使用XML和XSTL进行数据交换与处理,使用XMLHttpRequest对象进行异步数据读取,使用Javascript绑定和处理所有数据。
与传统的Web应用不同,AJAX采用异步交互过程。AJAX在用户与服务器之间引入一个中间媒介,从而消除了网络交互过程中的处理-等待-处理-等待缺点。用户的浏览器在执行任务时即装载了AJAX引擎。AJAX引擎用JavaScript语言编写,通常藏在一个隐藏的框架中。它负责编译用户界面及与服务器之间的交互。AJAX引擎允许用户与应用软件之间的交互过程异步进行,独立于用户与网络服务器间的交流。现在,可以用Javascript调用AJAX引擎来代替产生一个HTTP的用户动作,内存中的数据编辑、页面导航、数据校验这些不需要重新载入整个页面的需求可以交给AJAX来执行。
使用AJAX,可以为ISP、开发人员、终端用户带来可见的便捷:
●减轻服务器的负担。AJAX的原则是“按需取数据”,可以最大程度的减少冗余请求,和响应对服务器造成的负担。
●无刷新更新页面,减少用户心理和实际的等待时间。特别的,当要读取大量的数据的时候,不用像Reload那样出现白屏的情况,AJAX使用XMLHTTP对象发送请求并得到服务器响应,在不重新载入整个页面的情况下用Javascript操作DOM最终更新页面。所以在读取数据的过程中,用户所面对的不是白屏,是原来的页面内容(也可以加一个Loading的提示框让用户知道处于读取数据过程),只有当数据接收完毕之后才更新相应部分的内容。这种更新是瞬间的,用户几乎感觉不到。
●带来更好的用户体验。可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。
●可以调用外部数据。基于标准化的并被广泛支持的技术,不需要下载插件或者小程序。进一步促进页面呈现和数据的分离。
综上所述,如何将AJAX技术应用于资源多页分配中,以将查询到的多页角色一次性全部与资源实现绑定或取消绑定,即为本领域技术人员所欲研究的方向所在。
发明内容
本发明的主要目的是提供一种基于AJAX的资源多页分配方法,其实现了将查询到的多页角色一次性全部与资源实现绑定或取消绑定。
为了达到上述目的,本发明提供一种基于AJAX的资源多页分配方法,其包括以下步骤:
步骤S1:对bindingSet进行初始化设置,将其初始集合设为数据库中与资源已绑定的角色主键;
步骤S2:用户在前台页面所进行的绑定/取消绑定操作反应到bindingSet的变化;
步骤S3:用户进行提交操作,将新集合bindingSet更新到数据库或其他存储实体。
较佳的实施方式中,在步骤S1中,通过所述的初始集合来确定复选框是否选中来展示查询出来的角色,查询到符合条件的角色列表,每个角色对应一个复选框,设置复选框的初始值。
较佳的实施方式中,在步骤S1中,是通过主键在bindingSet检索,如果能检索到,该复选框为“选中”状态;反之则该复选框为“未选中”状态。
较佳的实施方式中,在步骤S2中,所述绑定/取消绑定包括单个角色绑定/取消绑定、当前页角色绑定/取消绑定和所有角色绑定/取消绑定。
较佳的实施方式中,在步骤S2中,提供一种查询角色分页的基类,其包含的主要私有变量为所有角色与资源绑定的主键集合bindingSet和全部绑定/全部取消绑定的布尔型变量allSelected,用户在前台页面所进行的绑定/取消绑定操作反应到bindingSet和allSelected的变化。
较佳的实施方式中,用户在前台所进行的单个角色与资源绑定/取消绑定以及当前页角色与资源绑定/取消绑定的操作会引起bindingSet的变化,查询到的角色全部实现与资源绑定/取消绑定操作会引起allSelected的变化,在页面管理BEAN中要根据上述变化,重新设置需要绑定到资源的角色主键集合bindingSet。
较佳的实施方式中,所述的在页面管理BEAN中生成的bindingSet,在更新到数据库时,需要与已和资源绑定的角色主键列表roleIds进行比对。
较佳的实施方式中,bindingSet和roleIds中都存在的角色主键,需要将这些主键从bindingSet移除。
较佳的实施方式中,roleIds中存在而bindingSet中不存在的角色主键,需要将这些主键对应的角色与资源解除绑定关系。
较佳的实施方式中,bindingSet中存在而roleIds中不存在的角色主键,需要将这些主键对应的角色与资源建立绑定关系。
与现有技术相比,本发明的有益效果在于:
通过轻松点击一个按钮或链接,一次性实现将查询到的附合条件的多页角色列表与资源进行绑定/取消绑定操作。
附图说明
图1为本发明提供的一种基于AJAX的资源多页分配方法流程图;
图2为是本发明基于Ajax的资源多页分配方法绑定到资源的角色主键集合bindingSet变动图;
图3为本发明基于Ajax的资源多页分配方法在管理BEAN中获取需要与资源绑定的角色主键集合bindingSet;
图4为本发明基于Ajax的资源多页分配方法将需要与资源绑定的角色主键集合bindingSet更新到数据库;
图5A至图5E为实现本发明的一个具体例子,是将公告分配给个人帐户,电子邮箱地址是标志个人帐户的身份信息。其中,图5A,即查询个人帐户;图5B,即查询到的个人帐户分页列表;图5C-1及图5C-2,即点击“全选”页面效果图;图5D-1及图5D-2,即点击“全不选”页面效果图;和图5E,即将公告对个人帐户的分配更新到数据库。
具体实施方式
以下结合附图,对本发明上述的和另外的技术特征和优点作更详细的说明。
本发明是一种基于AJAX的资源多页分配方法,其是基于AJAX的网页技术,将资源和查询到的多角色实现绑定或取消绑定操作。
本发明提供一种查询角色分页的基类,其包括的主要私有变量为所有角色与资源绑定的主键(或者是能代表角色唯一性的字段及结构体,以下同)集合bindingSet和全部绑定/全部取消绑定的布尔型变量allSelected。当用户在前台所进行的单个角色与资源绑定/取消绑定以及当前页角色与资源绑定/取消绑定操作会引起bindingSet变化。当查询到的角色全部实现与资源绑定/取消绑定操作会引起allSetected的变化。因此,用户在前台实现的绑定/取消绑定操作直接引起bindingSet和allSelected的变化,然后通过页面的管理BEAN将这种变化反应到需要绑定到资源的角色主键新集合bindingSet,最后通过提交操作更新到数据库或其他存储实体。
上述的前台页面采用AJAX技术,用户所进行的操作,例如:某个角色与资源绑定、某个角色与资源取消绑定;某页角色与资源绑定、某页角色与资源取消绑定;全部页角色与资源绑定以及全部页角色与资源取消绑定,都会动态反映到bindingSet的变动。
上述本发明基于AJAX的资源多页分配方法中所描述的bindingSet,其初始元素集合包括从数据库查询到的所有与资源绑定的角色主键,通过所述初始元素集合可以确定单个角色对应的与资源是否绑定的复选框控件初始状态是否选中;经过用户操作将角色与资源绑定/取消绑定操作,在页面的管理BEAN中得到需要与资源绑定的角色主键集合bindingSet,并将此集合与已知资源绑定的角色列表roleId比对,有下列几种情况:
bindingSet和roleIds中都存在的角色主键,需要将这些角色主键从bindingSet集合中移除;
roleIds中存在而bindingSet中不存在的角色主键,需要将这些角色主键对应的角色与资源解除绑定关系;
bindingSet中存在而roleIds中不存在的角色主键,需要将这些角色主键对应的角色与资源建立绑定关系。
上述的情况可以由表一中体现:表一为本发明基于Ajax的资源多页分配方法bindingSet中角色主键与已绑定的角色主键列表中主键是否存在相互关系操作表。
表一
综上,参阅图1,为本发明提供的一种基于AJAX的资源多页分配方法流程图,其具体步骤如下:
步骤S1:对bindingSet进行初始化设置,将其初始集合设为数据库中与资源已绑定的角色主键;
步骤S2:用户在前台页面所进行的绑定/取消绑定操作反应到bindingSet的变化;
步骤S3:用户进行提交操作,将新集合bindingSet更新到数据库或其他存储实体。
下面对上述步骤进行详细说明:
首先参阅图2,为本发明基于Ajax的资源多页分配方法绑定到资源的角色主键集合bindingSet变动图,如图所示:
首先,要对bindingSet进行初始化设置,将其初始集合设为数据库中与资源已绑定的角色主键,通过这个初始集合,可以确定复选框是否选中来展示查询出来的角色是否与资源进行了绑定,查询到符合条件的角色列表,每个角色对应一个复选框,设置复选框的初始值,这可以通过主键在bindingSet检索,如果能检索到,该复选框为“选中”状态;反之则该复选框为“未选中”状态。
其次,用户在前台页面对于角色绑定/取消绑定到资源的操作需要更新到集合bindingSet中,所述绑定/取消绑定包括单个角色绑定/取消绑定、当前页角色绑定/取消绑定和所有角色绑定/取消绑定,这个过程将在图3中详细描述。
最后,还要从bindingSet集合中移除已经和资源绑定的角色主键,这个过程将在图4中详细描述
请参阅图3所示,为本发明基于Ajax的资源多页分配方法在管理BEAN中获取需要与资源绑定的角色主键集合bindingSet;处理页面操作有个公用类,该类中包含有两个私有变量,一个是用户进行常规操作如单个角色绑定/取消绑定及页全选/页全不选操作引起变动的与资源绑定的角色主键集合bindingSet,另外一个变量是进行全部绑定/全部取消绑定引起变化的布尔型变量allSelected,其初始值为false。用户对前台页面的操作直接反应到这个公用类中集合bindingSet和变量allSelected的变化。但最终这两者要反应到需要与资源绑定的角色主键新集合bindingSet,其可以通过在页面管理BEAN中实现方法函数来处理,图3描述的即是此类方法的具体流程。
请参阅图3所示,首先初始化一个角色主键类型的空集合bindingSet;接着通过定义的公用类获取前台操作而引起变化的需要与资源绑定的角色主键集合bindingSet以及全部绑定/全部取消绑定引起变化的布尔型变量allSelected;其次根据查询条件查询得到角色主键列表,并设定遍历该列表的游标it;再其次通过游标it遍历列表,若对应节点的角色主键值roleId存在于bindingSet集合或allSelected为true(即全部绑定),即将roleId添加到新的需要绑定的角色主键临时集合temp中;最后将temp赋值给bindingSet,返回真正需要与资源绑定的角色主键新集合bindingSet。
请参照图4,为本发明基于Ajax的资源多页分配方法将需要与资源绑定的角色主键集合bindingSet更新到数据库。图3中通过与页面对应的管理BEAN得到真正需要与资源绑定的角色主键集合,但在用户进行绑定/取消绑定操作过程中,可能需要绑定资源的角色其实已经与资源绑定了。这样就要对bindingSet集合中主键对应的角色进行分类处理。
如图4所示,首先根据图3的方法获得真正需要与资源绑定的角色主键集合bindingSet,接着查询获得现有已经与资源绑定的角色主键列表,并设定遍历该列表的游标it,其次通过游标it遍历列表,若对应节点的角色主键值roleId存在于bindingSet集合,则将roleId从bindingSet移除,否则将roleId对应的角色与资源解除绑定关系;最后将bindingSet中所有主键对应的角色均与资源建立绑定关系。bindingSet集合是角色主键以及查询到的已与资源绑定的角色主键分别有“存在”和“不存在”两种情况,组合在一起就有四种情况,比如在bindingSet集合中存在的角色主键,也存在于已绑定的角色主键列表,则实施的操作是将该主键从bindingSet集合中移除,如表一所示。
图5A至图5E为实现本发明的一个具体例子,是将公告分配给个人帐户,电子邮箱地址是标志个人帐户的身份信息。包括图5A,即查询个人帐户;图5B,即查询到的个人帐户分页列表;图5C-1及图5C-2,即点击“全选”页面效果图;图5D-1及图5D-2,即点击“全不选”页面效果图;和图5E,即将公告对个人帐户的分配更新到数据库。
这个实施例是将公告分配给个人帐户,电子邮箱地址是标志个人帐户的身份信息。图5A是填写个人帐户查询条件,什么都不填,表示查询所有,得到图5B个人帐户分页列表,图中显示一共查到两页十四条记录,第一条记录前面的复选框已经选中,表示公告已分配到该个人帐户,点击页面上的“全选”链接,效果如图5C-1及图5C-2,两页所有记录前面的复选框都选中,若点击页面上的“全不选”链接,如图5D-1及图5D-2,两页的所有记录前面的复选框都变成未选中状态,点击页面下端的“确定”按钮,返回到公告管理页面,点击页面上数据操作第一行的“提交修改”如图5E,将公告对个人帐户的分配更新到数据库。
需要特别说明的是,本发明针对将资源分配给角色的实施例来进行阐述,反之亦然,即将角色分配给多页资源。
综上所述,本发明提供一种基于AJAX的资源多页分配方法,其通过与每个角色对应的复选框是否选中来实现其与资源的绑定/取消绑定操作;通过页面中点击“页全选”、“页全不选”的按钮或链接一次性批量实现当前页角色与资源的绑定/取消绑定操作;通过页面中点击“全选”、“全不选”的按钮或链接一次性批量实现查询到的附合条件的所有多页角色与资源的绑定/取消绑定操作。即本发明实现了将查询到的多页角色一次性全部与资源实现绑定或取消绑定。
以上说明对本发明而言只是说明性的,而非限制性的,本领域普通技术人员理解,在不脱离以下所附权利要求所限定的精神和范围的情况下,可做出许多修改,变化,或等效,但都将落入本发明的保护范围内。
Claims (4)
1.一种基于AJAX的资源多页分配方法,其特征在于,其包括以下步骤:
步骤S1:对bindingSet进行初始化设置,将其初始集合设为数据库中与资源已绑定的角色主键,通过所述初始集合可以确定单个角色对应的与资源是否绑定的复选框控件初始状态是否选中;
步骤S2:用户在前台页面所进行的绑定/取消绑定操作反映到bindingSet的变化的具体步骤是:提供一种查询角色分页的基类,该基类包含的主要私有变量为所有角色与资源绑定的主键集合bindingSet和全部绑定/全部取消绑定的布尔型变量allSelected,用户在前台页面所进行的绑定/取消绑定操作反映到bindingSet和allSelected的变化,用户在前台所进行的单个角色与资源绑定/取消绑定以及当前页角色与资源绑定/取消绑定的操作会引起bindingSet的变化,查询到的角色全部实现与资源绑定/取消绑定操作会引起allSelected的变化,在页面管理BEAN中要根据上述变化,重新设置需要绑定到资源的角色主键集合bindingSet;
步骤S3:用户进行提交操作,将新集合bindingSet更新到数据库或其他存储实体,在页面管理BEAN中生成的bindingSet,在更新到数据库时,需要与已和资源绑定的角色主键列表roleIds进行比对,bindingSet和roleIds中都存在的角色主键,需要将这些主键从bindingSet移除,roleIds中存在而bindingSet中不存在的角色主键,需要将这些主键对应的角色与资源解除绑定关系,bindingSet中存在而roleIds中不存在的角色主键,需要将这些主键对应的角色与资源建立绑定关系。
2.根据权利要求1所述的基于AJAX的资源多页分配方法,其特征在于,在步骤S1中,通过所述的初始集合来确定复选框是否选中来展示查询出来的角色,查询到符合条件的角色列表,每个角色对应一个复选框,设置复选框的初始值。
3.根据权利要求2所述的基于AJAX的资源多页分配方法,其特征在于,在步骤S1中,是通过主键在bindingSet检索,如果能检索到,该复选框为“选中”状态;反之则该复选框为“未选中”状态。
4.根据权利要求1所述的基于AJAX的资源多页分配方法,其特征在于,在步骤S2中,所述绑定/取消绑定包括单个角色绑定/取消绑定、当前页角色绑定/取消绑定和所有角色绑定/取消绑定。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010164453 CN102236673B (zh) | 2010-04-30 | 2010-04-30 | 一种基于ajax的资源多页分配方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201010164453 CN102236673B (zh) | 2010-04-30 | 2010-04-30 | 一种基于ajax的资源多页分配方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102236673A CN102236673A (zh) | 2011-11-09 |
CN102236673B true CN102236673B (zh) | 2013-11-06 |
Family
ID=44887329
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN 201010164453 Active CN102236673B (zh) | 2010-04-30 | 2010-04-30 | 一种基于ajax的资源多页分配方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN102236673B (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103885943B (zh) * | 2012-12-19 | 2018-04-27 | 北大方正集团有限公司 | 网页中的下拉列表框控件的实现方法 |
CN103744645A (zh) * | 2013-03-01 | 2014-04-23 | 王新 | 一种基于ajax的资源多页分配方法 |
CN105550000B (zh) * | 2015-12-22 | 2019-03-01 | 金蝶软件(中国)有限公司 | 一种移动端滑动插件的生成方法及系统 |
CN111459972A (zh) * | 2020-04-07 | 2020-07-28 | 上海熙菱信息技术有限公司 | 一种大数据设备选择交互方法及系统 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2002312363A (ja) * | 2001-04-10 | 2002-10-25 | Mitsubishi Electric Corp | 情報配信方法および情報配信装置 |
CN1783088A (zh) * | 2004-12-01 | 2006-06-07 | 佳能株式会社 | Web浏览器的操作方法和操作装置 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8131591B2 (en) * | 2007-09-12 | 2012-03-06 | Microsoft Corporation | Updating contents of asynchronously refreshable webpages |
-
2010
- 2010-04-30 CN CN 201010164453 patent/CN102236673B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2002312363A (ja) * | 2001-04-10 | 2002-10-25 | Mitsubishi Electric Corp | 情報配信方法および情報配信装置 |
CN1783088A (zh) * | 2004-12-01 | 2006-06-07 | 佳能株式会社 | Web浏览器的操作方法和操作装置 |
Also Published As
Publication number | Publication date |
---|---|
CN102236673A (zh) | 2011-11-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102521230B (zh) | 用于有条件的数据显示的结果类型 | |
US9361390B2 (en) | Web content management | |
US8356274B2 (en) | System and methods to create a multi-tenancy software as a service application | |
JP5809328B2 (ja) | ウィジェットフレームワーク、リアルタイムサービス統合およびリアルタイムリソース集約 | |
KR101376916B1 (ko) | 소프트웨어 애플리케이션을 신규 버전의 소프트웨어 애플리케이션으로 점진적으로 업그레이드하기 위한 방법, 기계 판독가능 저장 매체를 포함하는 제품 및 장치 | |
CN102142014B (zh) | 导入和导出位于元数据注册系统中的元数据的系统和方法 | |
CN112930529B (zh) | 从概念数据模型生成软件工件 | |
CN104980512B (zh) | 一种基于移动应用提供目标对象的方法与设备 | |
US8904363B2 (en) | Projecting software and data onto client | |
CN104281455A (zh) | 一种接口调用方法、装置及终端 | |
CN102236673B (zh) | 一种基于ajax的资源多页分配方法 | |
CN112612449A (zh) | 一种网页页面的同步方法及装置、设备、存储介质 | |
CN103946794A (zh) | 数据特征的滚动升级的系统和方法 | |
CN114444478A (zh) | 一种凭证可视化方法、装置、电子设备及存储介质 | |
CN114461209A (zh) | 页面配置与切换方法、装置、设备及存储介质 | |
CN103501341A (zh) | 一种Web服务的创建方法及装置 | |
US7856344B2 (en) | Method for transforming overlapping paths in a logical model to their physical equivalent based on transformation rules and limited traceability | |
CN115311399A (zh) | 图像渲染方法、装置、电子设备以及存储介质 | |
CN102184112B (zh) | 控件升级方法及装置 | |
CN103744645A (zh) | 一种基于ajax的资源多页分配方法 | |
CN104508656A (zh) | 在分布式计算系统中的自动化文档复制 | |
CN112965944B (zh) | 可视化的页面还原方法及系统、电子设备及存储介质 | |
JP2009122949A (ja) | Xmlデータ構造の復元システム、xmlデータ構造の復元方法、およびxmlデータ構造の復元プログラム | |
CN117193740A (zh) | 数据分配方法、装置、计算设备及存储介质 | |
CN117764041A (zh) | 表单页面的更新方法、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant |