• [ExtJs] ExtJs4.2 数据模型Ext.data.Model学习


    Model代表应用程序管理的一些对象。例如,我们可能会为 我们想在系统中建模的现实世界中的一些物体像使用者、产品和汽车等定义一个Model。这些Model在 Ext.ModelManager中注册,被Ext.data.Store使用, 而这些Ext.data.Store又被许多 Ext中许多与数据绑定的组件使用.

    直接上代码:

    <%--
      Created by IntelliJ IDEA.
      User: Administrator
      Date: 2015/12/13 0013
      Time: 08:51
      To change this template use File | Settings | File Templates.
    --%>
    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
    
       <jsp:include page="resource.jsp"></jsp:include>
        <title>Ext数据模型Ext.data.Model</title>
    </head>
    <body>
    
    <script type="text/javascript">
    Ext.onReady(function(){
       // Ext.Msg.alert('提示','确定要删除此文件吗?');
    
        Ext.define("MyExt.User",{
            extend:"Ext.data.Model",
            fields:[
                {name: 'name',  type: 'string'},
                {name: 'age',   type: 'int', convert: null},
                {name: 'phone', type: 'string'},
                {name: 'email', type: 'string'},
                {name: 'alive', type: 'boolean', defaultValue: true, convert: null},//默认值
    //转换器 {name:
    'birth',type:'date',convert:function(value,record){ if(Ext.isDate(value)){ return value; }else if(Ext.isString(value)){
    //格式化
    return Ext.Date.parse(value,'Y-m-d'); } }} ], validations:[ { field: 'phone', type: 'length', min: 8, max: 13}, { field: 'email', type: 'email'} ], //自定义方法 sayHello:function(msg){ Ext.Msg.alert('提示',msg); } }); var user = Ext.create('MyExt.User'); user.sayHello('Ext的数据模型'); //为指定字段重新赋值 user.set('name','小黄'); //获取指定字段的值 console.info(user.get("name")); console.info(user.get('alive'));//true //修改默认字段值的数据 user.set('alive',false); console.error(user.get('alive'));//false console.info('************数据转换开始**************') var user_2 = Ext.create('MyExt.User',{ name:'我靠,where is my future?', birth:'2032-12-12', phone:'213', email:'54353.com' }); console.info(user_2.get('birth')); //Sun Dec 12 2032 00:00:00 GMT+0800 (中国标准时间) /** * 验证电话 validations */ //长度错误 Ext.data.validations.lengthMessage = "长度错误"; Ext.data.validations.emailMessage="邮箱格式错误!"; var validMsg= user_2.validate(); var msgs=[]; if(!validMsg.isValid()){ validMsg.each(function(msg){ msgs.push(msg.field+'字段验证信息:'+msg.message); }); } Ext.Msg.alert('提示',msgs.join('<br/>')); }); </script> </body> </html>

    更多请参考:

    ExtJS 4.2教程-04:数据模型

  • 相关阅读:
    [置顶] 图书推荐:SQL Server 2012 T-SQL基础 Itzik Ben-Gan
    UVA1366-----Martian Mining------DP
    动态规划——最长公共子序列(LCS)
    需求分析挑战之旅(疯狂的订餐系统)(3)——背景-需要-需求规格
    JavaScript学习笔记(四十四) 装饰器
    C中的volatile用法
    Java注解Annotation学习
    非常好!讲逻辑回归的,讲得很透彻
    RPC的学习 & gprotobuf 和 thrift的比较
    僵尸进程学习 & 进程状态列表 & Linux信号学习
  • 原文地址:https://www.cnblogs.com/lonelywolfmoutain/p/5042408.html
Copyright © 2020-2023  润新知