JSPatch下发笔记2

简介: JSPatch下发笔记2

原代码

@implementation HomeViewSubController
- (void)loadBanner{
    NSDictionary *parameters = [NSMutableDictionary dictionary];
    [parameters setValue:@"5" forKey:@"type"];
    __weak typeof(self) weakSelf = self;
    [[NSNetworking sharedManager]get:@"/api/slider/list" parameters:parameters success:^(id response) {
        BannerScrollModel *bannerScrollModel = [[BannerScrollModel alloc]initWithDictionary:response error:nil];
        [weakSelf.bannerArray removeAllObjects];
        [weakSelf.banners removeAllObjects];
        [weakSelf.bannerArray addObjectsFromArray:bannerScrollModel.items];
        for (NSInteger i = 0; i < bannerScrollModel.items.count; i++) {
            BannerModel *model = bannerScrollModel.items[i];
            [weakSelf.banners addObject:model.img_url];
        }
        if (weakSelf.bannerArray.count != 0) {
            _homeHeaderView.bannerCollection.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 225);
            if (_model.ZN_activity.boolValue == YES) {
                _homeHeaderView.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 230+_homeHeaderView.earlyBirdView.height);
            }else{
                _homeHeaderView.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 220+_homeHeaderView.earlyBirdView.height);
            }
        }else{
            _homeHeaderView.bannerCollection.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 0);
            _homeHeaderView.earlyBirdView.top = 5;
            _homeHeaderView.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width,_homeHeaderView.earlyBirdView.height+0.01);
        }
        weakSelf.tableView.tableHeaderView = _homeHeaderView;
        _homeHeaderView.bannerCollection.imagesArr = weakSelf.banners;
        _homeHeaderView.bannerCollection.imagesCount = weakSelf.bannerArray.count;
    } failure:^(NSString *error, int code) {
        [MBProgressHUD hideAllHUDsForView:weakSelf.view animated:YES];
        [WKProgressHUD popMessage:error inView:weakSelf.view duration:1.0 animated:YES];
    }];
}
@end


JS代码

require('NSMutableDictionary,NSNetworking,BannerScrollModel,UIScreen,MBProgressHUD,WKProgressHUD');
defineClass('HomeViewSubController', {
            loadBanner: function() {
            var parameters = NSMutableDictionary.dictionary();
           parameters.setValue_forKey("5", "type");
           var weakSelf = __weak(self); 
       NSNetworking.sharedManager().get_parameters_success_failure("/api/slider/list", parameters, block('id', function(response) {                                                                                                    var bannerScrollModel = BannerScrollModel.alloc().initWithDictionary_error(response, null);                                                                                                weakSelf.bannerArray().removeAllObjects();                                                                                                    weakSelf.banners().removeAllObjects();
                weakSelf.bannerArray().addObjectsFromArray(bannerScrollModel.items());
                for (var i = 0; i < bannerScrollModel.items().count(); i++) {
                var model = bannerScrollModel.valueForKey("items").objectAtIndex(i);
                weakSelf.banners().addObject(model.valueForKey("img_url"));
            }
                console.log(weakSelf.banners());
                var _homeHeaderView = weakSelf.valueForKey("_homeHeaderView");
                console.log(_homeHeaderView);
                var screenBounds = UIScreen.mainScreen().bounds();
                if (weakSelf.bannerArray().count() != 0) {
                _homeHeaderView.bannerCollection().setFrame({x:0, y:0, width:screenBounds.width, height:225});
                if (weakSelf.valueForKey("_model").valueForKey("ZN_activity").boolValue() == YES) {
                _homeHeaderView.setFrame({x:0, y:0, width:screenBounds.width, height:(230 + _homeHeaderView.earlyBirdView().height())});
           } else {
                _homeHeaderView.setFrame({x:0, y:0, width:screenBounds.width, height:(220 + _homeHeaderView.earlyBirdView().height())});
           }
           } else {
                _homeHeaderView.bannerCollection().setFrame({x:0, y:0, width:screenBounds.width, height:0});
                _homeHeaderView.earlyBirdView().setTop(5);
                _homeHeaderView.setFrame({x:0, y:0, width:screenBounds.width, height:_homeHeaderView.earlyBirdView().height() + 0.01});
            }
                weakSelf.tableView().setTableHeaderView(_homeHeaderView);
                _homeHeaderView.bannerCollection().setImagesArr(weakSelf.banners());
                _homeHeaderView.bannerCollection().setImagesCount(weakSelf.bannerArray().count());
            }), block('NSString*,int', function(error, code) {
                MBProgressHUD.hideAllHUDsForView_animated(weakSelf.view(), YES);
                WKProgressHUD.popMessage_inView_duration_animated(error, weakSelf.view(), 1.0, YES);
            }));
            },
            });


注意:


1.block中的self要在block外面声明成:

_ _weak typeof(self) weakSelf = self;

JS写法:var weakSelf = __weak(self);

2.for in循环改成for循环

3.多处用到实例变量的时候可以先声明再使用

如:var _homeHeaderView = weakSelf.valueForKey("_homeHeaderView");

4.获取屏幕宽度的方法:UIScreen.mainScreen().bounds().width

5.CGRectMake(0,0,5,10)写成{x:0,y:0,width:5,height:10}

目录
相关文章
|
4月前
|
JavaScript 前端开发
Vue、ElementUI配合Node、multiparty模块实现图片上传并反显_小demo
如何使用Vue和Element UI配合Node.js及multiparty模块实现图片上传并反显的功能,包括前端的Element UI组件配置和后端的Node.js服务端代码实现。
67 1
|
8月前
|
安全
JSPatch被停用了,也就是不能使用JSPatch第三方框架热修复了
JSPatch被停用了,也就是不能使用JSPatch第三方框架热修复了
118 0
|
8月前
|
JavaScript API
Vue.js组件精讲 组件的通信2:派发与广播——自行实现dispatch和broadcast方法
Vue.js 的 provide/inject API 主要用于跨级组件通信,侧重于子组件获取上级状态。但无法良好处理两种场景:父向子(跨级)传递数据和子向父(跨级)传递数据。在这种情况下,虽然Vue推荐使用Vuex,但在某些场景下,可以使用自定义的`dispatch`和`broadcast`方法。这两个方法在Vue 1.x中存在,但在2.x中被废弃。`$emit`用于触发当前组件的自定义事件,而`$on`用于监听这些事件。在Vue 2.x中,我们将自行实现`dispatch`和`broadcast`以实现类似的功能,允许父子组件(包括跨级)之间的通信,特别是当组件层级不深且无需全面状态管理时
64 0
|
算法
vue2-patch流程分析
我们在上篇文章分析了虚拟节点的创建及渲染流程,其中也有简单分析了 patch 过程,但是对于新旧节点的对比逻没有去仔细分析,所以我们打算好好梳理下 patch 的整个流程。
|
Web App开发 JavaScript iOS开发
JSPatch 断点调试
JSPatch 断点调试
155 0
JSPatch 断点调试
|
JavaScript
JSPatch下发笔记9
JSPatch下发笔记9
112 0
|
JavaScript
JSPatch下发笔记1
JSPatch下发笔记1
122 0
|
JavaScript
JSPatch下发笔记10
JSPatch下发笔记10
117 0
|
JavaScript
JSPatch下发笔记3
JSPatch下发笔记3
130 0
|
JavaScript
JSPatch下发笔记4
JSPatch下发笔记4
132 0