1、输入框样式
class="mini-textbox" //普通输入框
class="mini-password" //密码输入框
class="mini-textarea" //文本输入框
lass="mini-datepicker" //日期选择(value="2010-10-12")
class="mini-spinner" //数字框(value="22" minValue="10" maxValue="50")
class="mini-timespinner" //时间微调(format="H:mm")
class="mini-checkbox" //选择框(value="Y" trueValue="Y" falseValue="N")
class="mini-combobox" //下拉选择框(showNullItem="true" url="../data/countrys.txt" textField="text" valueField="id" value="cn")
class="mini-treeselect" //树选择框(url="../data/listTree.txt" multiSelect="true" textField="text" valueField="id" parentField="pid" checkRecursive="true"
value="ajax")
class="mini-checkboxlist" //复选框(repeatItems="3" repeatLayout="flow" url="../data/countrys.txt" value="cn,de,usa" textField="text" valueField="id")
class="mini-radiobuttonlist" //单选框(value="en" repeatItems="4" repeatDirection="vertical" repeatLayout="table" url="../data/countrys.txt"
textField="text" valueField="id")
class="mini-listbox" //展开的选择框(url="../data/countrys.txt" value="fr" textField="text" valueField="id" style="height:120px;")
2、输入校验
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>表单验证规则总结</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8" /><link href="../demo.css" rel="stylesheet" type="text/css" />
<script src="../../scripts/boot.js" type="text/javascript"></script>
<style type="text/css">
.td1
{
text-align:right;
}
.td2
{
padding-left:15px;
font-size:13px;
font-family:Tahoma;
}
</style>
</head>
<body>
<h1>表单验证规则总结</h1>
<div id="form1" >
<table>
<tr>
<td class="td1">不允许为空:</td>
<td>
<input class="mini-textbox" required="true" />
</td>
<td class="td2">required="true"</td>
</tr>
<tr>
<td class="td1">必须是邮箱地址:</td>
<td>
<input class="mini-textbox" vtype="email" required="true"/>
</td>
<td class="td2">vtype="email"</td>
</tr>
<tr>
<td class="td1">必须是URL:</td>
<td>
<input class="mini-textbox" vtype="url" required="true"/>
</td>
<td class="td2">vtype="url"</td>
</tr>
<tr>
<td class="td1">必须是整数(int):</td>
<td>
<input class="mini-textbox" vtype="int" required="true"/>
</td>
<td class="td2">vtype="int"</td>
</tr>
<tr>
<td class="td1">必须是数字(float):</td>
<td>
<input class="mini-textbox" vtype="float" required="true"/>
</td>
<td class="td2">vtype="float"</td>
</tr>
<tr>
<td class="td1">字符串长度(<= 6):</td>
<td>
<input class="mini-textbox" vtype="maxLength:6" required="true"/>
</td>
<td class="td2">vtype="maxLength:6"</td>
</tr>
<tr>
<td class="td1">字符串长度(>= 2):</td>
<td>
<input class="mini-textbox" vtype="minLength:2" required="true"/>
</td>
<td class="td2">vtype="minLength:2"</td>
</tr>
<tr>
<td class="td1">字符串长度(2-6):</td>
<td>
<input class="mini-textbox" vtype="rangeLength:2,6" required="true"/>
</td>
<td class="td2">vtype="rangeLength:2,6"</td>
</tr>
<tr>
<td class="td1">字符数个数(2-6):</td>
<td>
<input class="mini-textbox" vtype="rangeChar:2,6" required="true"/>
</td>
<td class="td2">vtype="rangeChar:2,6"</td>
</tr>
<tr>
<td class="td1">数字范围(0-100):</td>
<td>
<input class="mini-textbox" vtype="range:0,100" required="true"/>
</td>
<td class="td2">vtype="range:0,100"</td>
</tr>
<tr>
<td class="td1">必须是日期格式(如yyyy-MM-dd):</td>
<td>
<input class="mini-textbox" vtype="date:yyyy-MM-dd" required="true"/>
</td>
<td class="td2">vtype="date:yyyy-MM-dd"</td>
</tr>
<tr>
<td class="td1">必须是日期格式(如MM/dd/yyyy):</td>
<td>
<input class="mini-textbox" vtype="date:MM/dd/yyyy" required="true"/>
</td>
<td class="td2">vtype="date:MM/dd/yyyy"</td>
</tr>
<tr>
<td class="td1" style="color:Red;">邮箱格式,5~20个字符(组合):</td>
<td>
<input class="mini-textbox" vtype="email;rangeLength:5,20;" required="true"/>
</td>
<td class="td2">vtype="email;rangeLength:5,20;"</td>
</tr>
<tr>
<td class="td1" style="color:Red;">必须输入英文(自定义):</td>
<td>
<input class="mini-textbox" onvalidation="onEnglishValidation" />
</td>
<td class="td2">onvalidation="onEnglishValidation"</td>
</tr>
<tr>
<td class="td1" style="color:blue;">必须输入英文(自定义vtype):</td>
<td>
<input class="mini-textbox" vtype="english"/>
</td>
<td class="td2">vtype="english"</td>
</tr>
<tr>
<td class="td1" style="color:Red;">必须输入英文+数字(自定义):</td>
<td>
<input class="mini-textbox" onvalidation="onEnglishAndNumberValidation" />
</td>
<td class="td2">onvalidation="onEnglishAndNumberValidation"</td>
</tr>
<tr>
<td class="td1" style="color:Red;">必须输入中文(自定义):</td>
<td>
<input class="mini-textbox" onvalidation="onChineseValidation" />
</td>
<td class="td2">onvalidation="onChineseValidation"</td>
</tr>
<tr>
<td class="td1" style="color:Red;">身份证验证15~18位(自定义):</td>
<td>
<input class="mini-textbox" onvalidation="onIDCardsValidation" />
</td>
<td class="td2">onvalidation="onIDCardsValidation"</td>
</tr>
<tr>
<td></td>
<td>
<input value="Login" type="button" onclick="submitForm()" />
</td>
</tr>
</table>
</div>
<script type="text/javascript">
mini.parse();
function submitForm() {
var form = new mini.Form("#form1");
form.validate();
if (form.isValid() == false) return;
//提交数据
var data = form.getData();
var json = mini.encode(data);
$.ajax({
url: "../data/FormService.aspx?method=SaveData",
type: "post",
data: { submitData: json },
success: function (text) {
alert("提交成功,返回结果:" + text);
}
});
}
function onEnglishValidation(e) {
if (e.isValid) {
if (isEnglish(e.value) == false) {
e.errorText = "必须输入英文";
e.isValid = false;
}
}
}
function onEnglishAndNumberValidation(e) {
if (e.isValid) {
if (isEnglishAndNumber(e.value) == false) {
e.errorText = "必须输入英文+数字";
e.isValid = false;
}
}
}
function onChineseValidation(e) {
if (e.isValid) {
if (isChinese(e.value) == false) {
e.errorText = "必须输入中文";
e.isValid = false;
}
}
}
function onIDCardsValidation(e) {
if (e.isValid) {
var pattern = /\d*/;
if (e.value.length < 15 || e.value.length > 18 || pattern.test(e.value) == false) {
e.errorText = "必须输入15~18位数字";
e.isValid = false;
}
}
}
/* 是否英文 */
function isEnglish(v) {
var re = new RegExp("^[a-zA-Z\_]+$");
if (re.test(v)) return true;
return false;
}
/* 是否英文+数字 */
function isEnglishAndNumber(v) {
var re = new RegExp("^[0-9a-zA-Z\_]+$");
if (re.test(v)) return true;
return false;
}
/* 是否汉字 */
function isChinese(v) {
var re = new RegExp("^[\u4e00-\u9fa5]+$");
if (re.test(v)) return true;
return false;
}
/*自定义vtype*/
mini.VTypes["englishErrorText"] = "请输入英文";
mini.VTypes["english"] = function (v) {
var re = new RegExp("^[a-zA-Z\_]+$");
if (re.test(v)) return true;
return false;
}
</script>
<div class="description">
<h3>Description</h3>
<p>
</p>
</div>
</body>
</html>
3、表单操作
class="mini-datagrid"
if (form.isValid() == false) return;
var form = new mini.Form("#form1");
var data = form.getData(); //获取表单多个控件的数据
form.setData(data); //设置控件数据
form.unmask();
form.clear(); //清除表单
form.reset(); //重置表单
4、注意
**4.1、**Miniui中的mini.pause()语句要写,要不然后面的用到mini会失效。
**4.2、**习惯F12看JS是否报错!!!有时间学会调试‘’
**4.3、**页面加载完之后就运行的函数$(function() ,JS的运行顺序是按照HTML中
$(function() {
//为多记录渲染字典项提供数组容器
$("#cxJg").data("miniDictData", {});
kfsglBtn.doQuery();
})
**4.4、**在html页面中声明全局变量,在其他的js文件中都可以用到
**4.5、**要使用service中得到的值,现在页面开始加载之前使用<%执行java代码,声明变量%>,用<%=%>在html中引用变量
<%
String ctx = request.getContextPath();
String rightid = DTOUtil.getValue("RightID"); //权限id
String operId=(String)request.getSession().getAttribute("OPERID"); //得到当前操作员id
IOperator Operator = null;
Object obj = request.getSession().getAttribute(ConVar.LOGIN_SESSION_ID);
if(obj != null){
Operator = (IOperator)obj;
}
String operPosition=Operator.getPOSITION(); //获取当前用户的开发商id
String operType=Operator.getOperType(); //获取当前用户的管理员类型
%>
<input class="mini-hidden" name="OPERID" id="OPERID" value="<%=operId%>"/>
<input class="mini-hidden" name="OPERPOSITION" id="OPERPOSITION" value="<%=operPosition%>"/>
<input class="mini-hidden" name="OPERTYPE" id="OPERTYPE" value="<%=operType%>"/>
4.6、 JS闭包示例
1、声明一个变量,该变量指定一个函数;
2、声明该变量的_KfsglInit.prototype={函数1,函数2…}
3、建立一个该变量的实例,var kfsglInit = new _KfsglInit();
4、该变量里面所有的函数都实例+函数名进行调用,在该变量函数内部也是通过该方式调用。
var _KfsglInit = function() {};
_KfsglInit.prototype = {
fInitialize : function(options) {},
fnPageInit : function(){
},
/**
* 初始化表格
*/
onActionRenderer: function(e) {
var record = e.record;
var column = e.column;
var rowIndex = e.rowIndex;
var id = record.ID;
var kfsmc = record.KFSMC;
if (column.name == 'CZ') {
e.cellHtml = ' <a class="Edit_Button" href="javascript:kfsglBtn.selectRow(\'' + id + '\')" >查看</a>'
+ ' <a class="Delete_Button" href="javascript:kfsglBtn.updateRow(\'' + id + '\')">修改</a>'
+ ' <a class="Delete_Button" href="javascript:kfsglBtn.deleteRow(\'' + id + '\''+','+'\'' + kfsmc + '\')">删除</a>';
}
}
};
var kfsglInit = new _KfsglInit();
**4.7、**属性和方法
1、miniui中得到form; var form = new mini.Form("#xtxzForm");
5、miniui中得到form的值 ;var params = form.getData(true);
2、miniui中设置form不可编辑 ;form.setEnabled(false);
3、miniui中得到控件,设置控件是否可以编辑 ;mini.get(“SSKFS”).setEnabled(false);
4、miniui中得到控件,得到控件是否可以编辑 ;mini.get(“SSKFS”).getEnabled();
6、miniui中判断控件是否可以编辑;mini.get(“XTMC”).enabled==false
7、miniui中得到控件,设置控件的值 ;mini.get(“KFSID”).setValue(kfsid);
8、miniui中得到控件,得到控件的值 ;var value=mini.get(“KFSID”).getValue();