JSPatch下发笔记9

简介: JSPatch下发笔记9

OC代码:

-(void)rightBarButtonItemPressed{
    NSString *js = @"document.getElementsByTagName('meta')['Description']['content']";
    UIImageView *imageView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"neisha_logo"]];
    imageView.hidden=YES;
    [self.view addSubview:imageView];
    UIImage *image=[[SDImageCache sharedImageCache] imageFromDiskCacheForKey:_imageUrl];
        [MBProgressHUD showHUDAddedTo:self.view animated:YES];
        [imageView sd_setImageWithURL:_imageUrl placeholderImage:[UIImage new] andType:3 completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
            [MBProgressHUD hideAllHUDsForView:self.view animated:YES];
            [self.webView.wkWebView evaluateJavaScript:js completionHandler:^(id _Nullable desc, NSError * _Nullable error) {
                [[ThirdShareManager sharedInstance] shareItemWithTitle:_title description:desc image:image url:_url controller:self block:nil];
            }];
        }];
}


JS代码:

rightBarButtonItemPressed: function() {
            var js = "document.getElementsByTagName\('meta')['Description']['content']";
            var imageView = UIImageView.alloc().initWithImage(UIImage.imageNamed("neisha_logo"));
            imageView.setHidden(1);
            self.view().addSubview(imageView);
            var _imageUrl = self.valueForKey("_imageUrl");
            var _url = self.valueForKey("_url");
            var _title = self.valueForKey("_title");
            console.log(_imageUrl);
            var image = SDImageCache.sharedImageCache().imageFromDiskCacheForKey(_imageUrl);
            MBProgressHUD.showHUDAddedTo_animated(self.view(), 1);
            imageView.sd__setImageWithURL_placeholderImage_andType_completed(_imageUrl, UIImage.new(), 3, block("void, UIImage*, NSError*, SDImageCacheType, NSURL*", function(image, error, cacheType, imageURL) {
                console.log(image);
                MBProgressHUD.hideAllHUDsForView_animated(self.view(), 1);
                self.webView().wkWebView().evaluateJavaScript_completionHandler(js, block("void, id, NSError", function(desc, error) {
                ThirdShareManager.sharedInstance().shareItemWithTitle_description_image_url_controller_block(_title, desc, image, _url, self, null);
                }));
            }));
            }


注:

OC中的字符串@"document.getElementsByTagName('meta')['Description']['content']";  在JS中要写成"document.getElementsByTagName('meta')['Description']['content']";

()前面要加上转义字符\

目录
相关文章
|
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 断点调试
JSPatch下发笔记6
JSPatch下发笔记6
107 0
|
JavaScript
JSPatch下发笔记10
JSPatch下发笔记10
117 0
|
JavaScript
JSPatch下发笔记4
JSPatch下发笔记4
132 0
|
JavaScript
JSPatch下发笔记1
JSPatch下发笔记1
122 0
|
JavaScript
JSPatch下发笔记8
JSPatch下发笔记8
133 0
|
JavaScript
JSPatch下发笔记7
JSPatch下发笔记7
139 0

热门文章

最新文章