威尼斯网址开户网站WPF 自定义控件基类

   ThinkPHP 提供了一个 Model 类,供其他的 Model 进行继承。Model 类中是
MVC 中的模型类,它是调用 持久层
的上层类。感觉这么描述问题很多,但是有什么办法呢?但是,这个 Model
有时无法满足我们的一些需求,因此我们需要自定义一个 Model
类出来,不过自定义的 Model 同样要继承 TP 提供的 Model
类,而把我们自定义的 Model 类作为我们项目中的 Model
基类。我怎么感觉我在说绕口令,等等…我有点晕。

本文实例讲述了ThinkPHP5.0框架控制器继承基类和自定义类。分享给大家供大家参考,具体如下:

项目开发中经常有些是常用到的控件.在每个界面都会有比如   返回上一层的back按钮   ,tableView列表控件 …….

iOS开发中,网络请求得到json转化为字典,然后字典转化为模型,这是很普遍要做的事。成型的第三方框架也有很多,前段时间比较火的YYKit中的YYMoel对各大这方面的框架包括JsonModel,MjExtension等效率都有所对比。但是授之以鱼不如授之以渔,有时候我们仅仅想要的就是字典转模型而已,简单,可控,可自定义。今天,小编我提供了一下自己的解决方案。

 

继承系统控制器基类:

一般都会建一个 basicViewController,作为基本视图  后面的每个控制器 都会继承使用.

威尼斯网址开户网站 1

继承BasicViewCtrl

威尼斯网址开户网站 2

继承后会显示继承的ctrl是什么类型

先来一波思路分析。后台返回的数据json(xml很少人在用了吧)的类型的数据格式有对象和数组,
字符串,数字布尔null,使用系统自带的NSJSONSerialization得到字典,会将对象转化为NSDictionary对象,数组转化为NSArray对象,字符串转化为NSString对象,数字和布尔类型转化为NSValue对象或者子类NSNumber对象,null转化为NSNull对象。json中的null这个就需要小心了。java的后台程序可能是直接将model转化为json,当对象没初始化为null时,json就会出现null,而不是应该有的{}。null会转化为NSNull,但是我们认为他是对象类型,转化为了NSDictionary对象,然后调用了objectForkey,就会报unRecognized selector exception使程序崩溃。关于这点,我曾经和做后台的同事争吵过,说:你既然定义json中某key的值是对象类型,为空你也要传“{}”啊({}会转化为空字典类型),为什么传null。他们争论到:从数据库中查不到,就没必要初始化model对象,转化为json也就会为null。我直接无语了。

无聊的需求

<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
  public function hello()
  {
    return 'hello,world';
  }
}

这里都会只继承 .h  .m文件中的生命周期的代码块,如果在.m中写了方法,其中可以在.h文件中声明.这样在子类也可以调用.

威尼斯网址开户网站 3

子类调用父类的方法(在.h中声明)

直接上代码吧。注释还是蛮清晰的,记得不要忘记把那两个“安全设置”加上,不然,碰到手误,忘记定义的属性,程序又该崩溃了。setNilValueForKey:这个不常用,是定义assign类型的属性给它set
nil才会触发。加上也不多。

  在使用 Java 的开源项目 JeeSite
时,养成了一个不好的习惯,习惯给每张表都增加
create_by、create_date、update_by、update_date、remarks 和 del_flag
这么几个字段。如果每张表都有这几个字段,那么对每张表进行 insert
时都会对以上的字段进行设置,对每张表进行 update
时都会对其中部分字段进行更新,对每条记录进行 delete 时都其实是对
del_flag 字段进行
置位。重复操作很多,一些操作方法被修改。那么,这个时候就要自定义一个自己的
Model 来作为项目的 基类 了,这个 Model 就负责干上面我说的那些事情了。

或者自定义一个基础控制器类Base:

如果在xib中  创建控件 而不会继承显示.需要自己手写在子类中继承父类的xib

威尼斯网址开户网站 4

- (instancetype)initWithDic:(NSDictionary*)dic{ if (!dic || ![dic isKindOfClass:[NSDictionary class]]) { return nil; } if (self = [super init]) { for (NSString *key in [dic allKeys]) { id value = dic[key]; //1.处理对象类型和数组类型 if ([value isKindOfClass:[NSArray class]] || [value isKindOfClass:[NSDictionary class]]) { [self setValue:value forKeyPath:key]; } //2.处理空类型:防止出现unRecognized selector exception else if ([value isKindOfClass:[NSNull class]]) {// [self setValue:nil forKey:key]; } //3.处理其他类型:包括数字,字符串,布尔,全部使用NSString来处理 else{ [self setValue:[NSString stringWithFormat:@"%@",value] forKeyPath:key]; } } } return self;}#pragma mark KVC 安全设置- setValue:value forUndefinedKey:(NSString *)key{ NSLog(@"%s",__func__);}- setNilValueForKey:(NSString *)key{ NSLog(@"%s",__func__);}

 

<?php
namespace app\index\controller;
use think\Controller;
class Base extends Controller
{
}

JSONModel有一个好处,就是我们在po或者log打印model对象的时候回直接展示他的属性值。其实就是重写description方法而已。我们也来一波自定义:

自定义一个 Model

可以在Base控制器类中定义一些公共方法(如果对类的基本知识不够熟悉的话,参考PHP的类与对象部分说的非常清楚,在此不做深入了)。

#pragma mark po或者打印时打出内部信息-(NSString *)description{ NSMutableString* text = [NSMutableString stringWithFormat:@"<%@> \n", [self class]]; NSArray* properties = [self filterPropertys]; [properties enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) { NSString* key = (NSString*)obj; id value = [self valueForKey:key]; NSString* valueDescription = ?[value description]:@""; if ( ![value respondsToSelector:@selector] && [valueDescription length]>60 ) { valueDescription = [NSString stringWithFormat:@"%@...", [valueDescription substringToIndex:59]]; } valueDescription = [valueDescription stringByReplacingOccurrencesOfString:@"\n" withString:@"\n "]; [text appendFormat:@" [%@]: %@\n", key, valueDescription]; }]; [text appendFormat:@"</%@>", [self class]];; return text; }

  自定义一个 Model,Model 中至少重新 TP 提供的 Model 中的
add、save、delete 和 select 方法。

然后应用下面的所有控制器类都继承Base:

方法调用了[self filterPropertys]获本类的所有属性。这个用到了所谓的“高大上”的objc的runtime中方法了。先来一波包含头文件#import <objc/runtime.h>。然后在上代码。

  定义代码如下:

<?php
namespace app\index\controller;
use app\index\controller\Base;
class Index extends Base
{
  public function hello()
  {
    return 'hello,world';
  }
}
#pragma mark 获取一个类的属性列表- (NSArray *)filterPropertys{ NSMutableArray* props = [NSMutableArray array]; unsigned int count; objc_property_t *properties = class_copyPropertyList([self class], &count); for(int i = 0; i < count; i++){ objc_property_t property = properties[i]; const char* char_f =property_getName; NSString *propertyName = [NSString stringWithUTF8String:char_f]; [props addObject:propertyName]; // NSLog(@"name:%s",property_getName); // NSLog(@"attributes:%s",property_getAttributes); } free(properties); return props;}
 1 <?php
 2 namespace Admin\Model;
 3 use Think\Model;
 4 
 5 /**
 6  * 项目中其他 Model 类的基类
 7  * 该类继承自 TP 提供的基类 Model
 8  */
 9 class BaseModel extends Model {
10     
11     /**
12      * 继承基类 Model 的 add 方法
13      * 自动插入 id create_by create_date update_by update_date del_flag
14      */
15     public function add($data='',$options=array(),$replace=false) {
16         
17         $data["id"]          = $this->getUuid();
18         $data["create_by"]   = "";
19         $data["create_date"] = date("Y-m-d H:i:s");
20         $data["update_by"]   = "";
21         $data["update_date"] = date("Y-m-d H:i:s");
22         $data["del_flag"]    = '0';
23         
24         return parent::add($data, $options, $replace);
25     }
26     
27     /**
28      * 获得 未删除 的所有数据
29      * 记录是否被删除通过 del_flag 字段来进行确定
30      */
31     public function select($options=array()) {
32         $map["del_flag"] = 0;
33         $this->where($map);
34         
35         return parent::select($options);
36     }
37     
38     /**
39      * 获取 全部 的所有数据
40      */
41     public function selectAll($options=array()) {
42         return parent::select($options);
43     }
44     
45     /**
46      * 更新数据
47      * 更新数据时,要更新 update_by update_date 两个字段
48      */
49     public function save($data='',$options=array()) {
50         $data["update_by"]   = "";
51         $data["update_date"] = date("Y-m-d H:i:s");
52         
53         return parent::save($data, $options);
54     }
55     
56     /**
57      * 删除也是更新
58      * 设置 删除 标志位即可
59      */
60     public function delete($data='',$options=array()) {
61         $data["del_flag"] = 1;
62         
63         return parent::save($data, $options);
64     }

建议给应用统一定义一个自己的控制器基类,方便后期扩展。

最后。字典转模型,你是转了,那模型转字典呢?作为一个实用主义的程序员,如果不是有需求用到了,我才不去想这个的,多烧脑子啊😄。开发时,有时候需要提交数据给后台,由于网络请求的封装,只需要传一个字典对象过去就行。如果需要把一个model对象所有属性都作为参数提交,那么就需要吧model转化为字典类型。方法如下:

  这样,我们的 BaseModel 就定义好了,以后项目中的 Model 就不再继承 TP
的 Model 类了,而是继承我们自定义的 BaseModel 了。

PHP不支持多继承,如果需要继承多个类,可以通过引入trait

#pragma mark 模型中的字符串类型的属性转化为字典-(NSDictionary*)modelStringPropertiesToDictionary{ NSArray* properties = [self filterPropertys]; NSMutableDictionary* dic = [NSMutableDictionary dictionary]; [properties enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) { NSString* key = (NSString*)obj; id value = [self valueForKey:key]; if ([value isKindOfClass:[NSString class]]) { NSString* va = (NSString*)value; if (va.length > 0) { [dic setObject:value forKey:key]; } } }]; return dic;}

 

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend
FrameWork框架入门教程》及《PHP模板技术总结》。

将以上代码封装一个BaseModel类,所有model类继承它。

继承我们定义的基类

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

以上只是根据自己的所学加以运用而已,一千个读者就有一千个哈姆雷特。好多东西不是没法解决,只是暂时不知道解决的办法而已。这篇文章是自己的所学的一个总结,希望对读者有所帮助。

  继承的 BaseModel 的方法和继承 Model 的方法是一样的,只是使用 use
引入命名空间到当前作用域时的需要修改为我们的命名空间,而不是再去使用 TP
提供的命名空间。代码如下:

您可能感兴趣的文章:

  • php执行多个存储过程的方法【基于thinkPHP】
  • 学习thinkphp5.0验证类使用方法
  • thinkPHP5框架auth权限控制类与用法示例
  • thinkPHP5实现的查询数据库并返回json数据实例
  • thinkPHP5实现数据库添加内容的方法
  • tp5(thinkPHP5)操作mongoDB数据库的方法
  • thinkphp5
    migrate数据库迁移工具
  • thinkPHP5框架数据库连贯操作之cache()用法分析
  • 针对thinkPHP5框架存储过程bug重写的存储过程扩展类完整实例
1 <?php
2 namespace Admin\Model;
3 use Admin\Model\BaseModel;
4 
5 class TrunkModel extends BaseModel {

  use 引入的命名空间是 Admin\Model\BaseModel ,因为我们定义的
BaseModel 的命名空间是 Admin\Model,因为这里的 TrunkModel 和 BaseModel
在一个命名空间下,省去 use 也是可以的。

 

  这样,在我们用 D 方法实例化 TrunkModel 的对象后,使用 add
方法插入数据时,就会先调用 BaseModel 中的 add
方法了,这样我们每张表都有的 create_by 等一系列字段就都会自动得到了。

相关文章