-
Notifications
You must be signed in to change notification settings - Fork 77
nForum Front
nForum1.1前端采用backbone.js作为前端MVC框架,整体框架页面无刷新,即有一个固定的前端(front)页面,其中包括页面顶部(header),左侧菜单(left menu)和底部(footer)。一般来说,每次请求只改变页面的中间部分(body),页面的URL类似于 http://DOMAIN/BASE/#!LINK ,其中LINK为body的路径。前端核心代码位于 app/www/js/forum.lib.js 。
-
BaseModel类:此类继承于Backbone.Model,主要包含ajax相关的成员变量,也就是说所有继承此类的model都可以由ajax来获取。
-
UserModel类:此类继承于BaseModel,表示一个用户,包含一个用户的成员变量,变量名与API的用户元数据一样。
-
SESSION对象:此对象为继承于UserModel类的实现,在前端初始化时(front_init)生成。它负责处理与当前用户相关的所有事物,包括登陆,退出,状态刷新。
-
BODY对象:此对象为Backbone.Model的实现,持有当前body部分的路径和内容,负责body部分的刷新和跳转
-
APP对象:此对象为Backbone.View的实现,负责html渲染,model事件处理,用户查询,加载提示等。
-
ROUTER对象,此对象为Backbone.Router的实现,负责无刷新的链接识别。
-
DIALOG对象,此对象BaseModel的实现,负责弹出层的实现,目前包括alertDialog(提示对话框),confirmDialog(确认对话框),formDialog(表单对话框),ajaxDialog(ajax提示框)
-
String.GBKlength()和String.GBKsubstr(start,length),用来处理GBK编码的字符串长度和字符串截取
-
$.random(),产生一个随机数
-
$.isIE(num),是否为IE浏览器,num可选,为ie浏览器版本
-
$.isMultiFile(),浏览器是否支持html文件上传
-
$.isTop(),判断当前页面是否是顶级页面
-
$.sizeFormat(),显示可读的文件大小
由于前端的整体ajax化,nForum1.0的链接模式 http://DOMAIN/BASE/LINK ,将变为 http://DOMAIN/BASE/#!LINK ,对于原来的链接会自动跳转至新的链接,此功能由 app/controllers/components/redirect_acl.php 控制并且在 app/config/redirectacl.php 中可以配置无需跳转的页面。
原进站页面在nForum1.1中改为BASE/index,如果访问前端框架为guest用户并且不含有#时,会跳转到/index页面,此功能由 app/config/nforum.php 的$config['site']['preIndex']控制。
nForum1.1使用手动方式打包css和javascript文件,打包的命令为
cake -app app buildasset
运行后会在app/www/css 和 app/www/js 目录下生成前端框架所需的css和javascript文件,文件名类似packXXXXX。你可以修改 app/vendors/shells/buildasset.php 文件来控制所要打包的文件内容。
一般来说,对于ajax网站spider是获取不到真实的网站内容的,所以nForum1.1针对spider可以输出网页的实际内容,在 app/controllers/components/redirect_acl.php 中可以配置spider列表,在列表中的spider可以获取链接的实际内容以便SEO。
nForum1.1的ajax请求返回的对象一般含有如下属性:
-
ajax_st:表示此次ajax请求的状态,1为成功,0为失败
-
ajax_code:表示此次ajax请求的状态码
-
ajax_msg:表示此次ajax请求的状态信息(GBK编码)
-
nForum1.1使用以ajax_开头的action作为处理ajax的action,系统会自动检测其ajax请求的合法性。
-
在ajax的action中使用controller->set方法,分配给no_html_data值作为ajax响应数据,如$this->set('no_html_data', array('foo'=>'bar'));输出的json对象为为{foo:'bar',ajax_st:1,ajax_code:001,ajax_msg:''}
-
如果设置no_ajax_info为true,则ajax响应不会含有ajax_st,ajax_code,ajax_msg三个属性,如$this->set('no_ajax_info', true);
-
controller->error()方法可以直接传入错误代码并产生相应的ajax响应,其ajax_st值为0,也可以单独设置ajax_st,ajax_code值,如果不设置ajax_st则默认ajax_st为1
-
ajax响应的输出格式由请求的url后缀决定,目前nForum1.1支持xml和json的输出格式,比如 http://DOMAIN/BASE/user/ajax_session.json 将输出json格式的当前用户信息
-
ajax请求是不会跳转至front界面的,所以不用在 app/config/redirectacl.php 中配置
DIALOG对象提供ajaxDialog方法,传入json格式的ajax响应并显示相应的提示消息。