BG-UI:一个后台UI框架

BG-UI,一个可以快速上手的后台UI框架

1.简述

此项目为后台UI框架,并根据url中的hash提供简单的路由功能,页面的数据渲染依然交给服务器端。

UI基于BootStrap3。兼容移动端。兼容IE8+及其它主流浏览器。

github地址

演示地址

2.目录结构


  1. public 
  2.   ┗css 
  3.     ┠vendor      //存放第三方css文件 
  4.     ┗basic.css   //基础css 
  5.   ┗images 
  6.   ┗js 
  7.     ┠vendor      //存放第三方js文件 
  8.     ┠ajaxForm.js //所有ajax提交都由ajaxForm.js进行包装(非第三方插件,为作者编写) 
  9.     ┗basic.js    //基础js 
  10. tpl 
  11.   ┠...           //存放演示页面,目录结构随意 
  12.   ┠... 
  13.   ┗index.html    //主页面 
  14. server            //存放测试用服务器脚本 
  15. index.html        //入口(登录页面)  

3.配置

在主页面加载basic.js文件之前定义:


  1. window.common_conf = { 
  2.     defaultHash: 'page/desktop.html',    //hash的缺省值 
  3.     baseURL: './'                        //见下文"路由" 
  4. };  

4.路由

实现方式:监听hashChange事件,利用"common_conf.baseURL" + "当前页面的hash"形成请求地址,并用ajax请求服务器来获取需要显示的html。

5.表单的提交、验证、回调

5.1基本用法

只要页面中的<form>标签中包含class为.J_ajaxSubmitBtn的元素,则此表单均受ajaxForm.js(非第三方插件,为作者编写)控制。

当.J_ajaxSubmitBtn元素被点击后,ajaxForm.js会自动收集<form>标签上的属性值,并形成一次ajax提交,例如:


  1. <form 
  2.     method="get" 
  3.     action="../server/ajaxReturn.json" 
  4.     data-validate="validate1" 
  5.     data-callBack="callback1" 
  6.     data-useDefaultCallBack="on" 
  7.     enterSend="on" 
  8.     data-sendingText="提交中" 
  9.     > 
  10.     <input type="text" placeholder="新闻标题" name="title"> 
  11.     <button type="button" class="btn btn-primary J_ajaxSubmitBtn">查询</button> 
  12. </form> 
  13.  
  14. <script> 
  15.     function validate1($from) { 
  16.         var title = $from.find('input[name="title"]'); 
  17.         if ($.trim(title.val()) == '') { 
  18.             return '新闻标题不能为空'; 
  19.         } 
  20.  
  21.         return true; 
  22.     } 
  23.     function callback1(returnData, $from) { 
  24.         console.log($from); 
  25.     } 
  26. </script>  
  • method:提交方式(必须设置)
  • action:提交地址(必须设置)
  • data-validate:提交之前的验证函数名
  • data-callBack:服务器响应后的自定义回调函数名
  • data-useDefaultCallBack:服务器响应后是否执行框架的默认动作。只要值不为'off'都会调用。
  • enterSend:是否支持回车提交。"on"为启用,其他都为不启用
  • data-sendingText:提交过程中.J_ajaxSubmitBtn的提示文字

5.2默认动作

前面的data-useDefaultCallBack配置项已经提到了,浏览器接到响应后ajaxForm.js会执行一些默认的动作。

执行的默认动作由服务器返回的json进行定义:


  1.   "referer": "", 
  2.   "refresh": true, 
  3.   "state": "success", 
  4.   "message": "提交成功" 
  5. }  
  • referer:刷新的目标地址,留空则表示刷新当前页
  • refresh:true|false是否刷新
  • state:提交是否成功,只有当值为"success"时才视为成功(才会判断是否执行刷新操作)
  • message:提示信息,state不为"success"时会进行提示

注意这里的referer的值为将要显示的页面对应的hash。如果提供的referer以http或https开头,则整个控制台都会被刷新

5.3验证

<form>标签中的data-validate用来配置验证函数名,此验证函数在进行ajax提交前会接收到被jQuery封装的form DOM对象(具体可查看"5.1基本用法"中的代码示例)。

自定义函数返回true则正常提交;可以返回字符串来对错误信息进行提示,错误的提示方式已经在框架中进行了封装。

作者:liyu365

来源:51CTO

时间: 2024-08-30 22:41:12

BG-UI:一个后台UI框架的相关文章

Redis Admin UI——一个Redis UI管理界面

Redis Admin UI--一个Redis UI管理界面   Redis的管理UI是由两部分组成:   1.An Ajax客户端的Web应用程序(基于谷歌的闭合库开发的:https://github.com/google/closure-library),它作为一个简单的静态HTML/ JS/ CSS的应用程序,可以很容易地修改,并从服务器组件分离和托管任何静态HTTP文件服务器上. 2.一个ServiceStack http://www.servicestack.net/ ASP.NET

WEBJX推荐10个带有漂亮UI组件的JavaScript框架

文章简介:十个拥有丰富 UI 组件的 JavaScript 开发框架. 如今,网上有各种各样的JavaScript框架用来简化 Web 应用开发.这些框架都提供了一些核心的特性,例如 DOM 操作,动画,事件处理以及 Ajax 交互,但不是都带有 UI 组件.今天这篇文章向大家推荐的10个JavaScript框架提供了丰富的 Web UI 组件,帮助你构建一致,可靠以及高度交互的漂亮用户界面. ExtJS ExtJS 是最流行的 JavaScript 框架之一,提供了非常丰富的 UI 组件,包括

jeasyui-找前端UI高手修改ACE-admin 框架为iframe模式

问题描述 找前端UI高手修改ACE-admin 框架为iframe模式 本公司在使用ACE-Admin 作为软件后台界面框架,但原框架是每次刷新页面的不很好适应我们需求. 现想参考JeasyUI框架的模式,把ACE-admin改一下,使其支持iframe方式 . 有这方面的高手可以认真查看附件中的要求,然后联系我们, 费用不是问题,只要能达到要求.http://test1.swkj.it/ace/ui_ace_admin42208006.rar QQ42208006

linux内核-如何安装一个没UI的linux2.6.18内核?

问题描述 如何安装一个没UI的linux2.6.18内核? 操作系统大作业要求编写一些内核模块,内核要求为2.6.18版本,不能有图形界面. 想请教下该在什么系统上面装这个内核呢? 小弟在最新Ubuntu版本上装了2.6.18,可是进不去,而且也有界面.我是不是应该找个老版本点的CentOS来装呢,求指教. 解决方案 自己编译一个内核就是没有GUI的,如果实在想用Ubuntu可以删掉X Window 解决方案二: 有UI 的直接在代码中把UI屏蔽了就可以了啊,一般发布的Ubuntu都是带UI的

jquery ui-jquery UI 一个页面中怎么显示多个slider

问题描述 jquery UI 一个页面中怎么显示多个slider 后面的文本框是slider的值,每一个slider 的值互不影响 解决方案 直接放多个就好了,原本就互相不影响 <div class="slider"></div><input type="text" /> <div class="slider"></div><input type="text"

SSH框架网上商城项目第3战之使用EasyUI搭建后台页面框架_java

前面两篇,我们整合了SSH并且抽取了service和action部分的接口,可以说基本开发环境已经搭建好了,这一节我们搭建一下后台的页面.我们讨论一下两种搭建方式:基于frameset和基于easyUI.最后我们会使用easyUI来开发.1. 抽取公共JSP页面我们先来看一下当前的jsp页面: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> &l

Magicodes.WeiChat——后台JS框架封装

Magicodes.WeiChat同时也致力于提高后台开发效率,因此对在后台前端这块也做了一定的封装.我们先来说说主要的框架JS--mwc.js和mwc_elements.js.这两个JS文件位于Scripts目录下的app目录: · mwc:前端框架定义,可以理解为接口定义 · mwc_elements:基于前端框架定义的具体实现 主要API功能如下: 1日志 日志函数用于向浏览器控制台输出日志信息,比如调试信息.警告信息.错误信息.灾难信息等等,兼容主流的浏览器.后续还会增强相关函数,目前只

学习通过Thread+Handler实现非UI线程更新UI组件(转)

  [Android线程机制]    出于性能考虑,Android的UI操作并不是线程安全的,这就意味着如果有多个线程并发操作UI组件,可能导致线程安全问题.为了解决这个问题,Android制定了一条简单的规则:只允许UI线程修改Activity里的UI组件    当一个程序第一次启动时,Android会同时启动一条主线程(Main Thread),主线程主要负责处理与UI相关的事件,如用户的按键事件,用户接触屏幕的事件及屏幕绘图事件,并把相关的事件分发到对应的组件进行处理.所以主线程通常又被叫

iframeWin For Easy UI. 为 Easy UI 扩展的支持IFrame插件

iframeWin For Easy UI. 为 Easy UI 扩展的支持IFrame插件 在一个项目中用了Easy UI,但是发现里面的 Dialog .Window.Messager 弹窗都不支持IFrame的方式, 于是自己动手基于Easy UI实现了一个插件. 目前Easy UI仍然使用GPL开源协议.   JS引用: <script type="text/javascript" src="jquery.min.js"></script&