美文网首页iOS 开发iosiOS
iOS开发--内嵌HTML编辑器 Objective-C 与 J

iOS开发--内嵌HTML编辑器 Objective-C 与 J

作者: 小兵快跑 | 来源:发表于2016-09-10 17:15 被阅读4115次

通过接近N天的努力. 终于在今天.IOS下内嵌HTML编辑器的Demo 基本实现.学习过程中,参考了很多网上的资料.很感谢这些分享资源的牛人.有你们才能顺利拿下这个比较特别的需求.
过程中找到两个比较好的HTML编辑器是ZSSRichTextEditorCKEditor,下面我会简单的介绍这两款HTML编辑器;途中难点在于,如何与内嵌HTML编辑器进行数据交互,接下来,进入正题:

ZSSRichTextEditor

ZSSRichTextEditor 是个漂亮的iOS富文本WYSIWYG所见即所得的编辑器,它包含了一个标准WYSIWYG编辑器所应该拥有的所有工具,此外还提供源代码语法高亮查看功能。

ZSSRichTextEditor-1.gif ZSSRichTextEditor--2.gif

CKEditor

CKEditor 是当前最为知名的 HTML 编辑器,它具有所有主流 HTML 编辑器所应当具备的特点:所见即所得、简单易用、开源并支持各种主流的浏览器(IE、Oper、FireFox、Chrome、Safari)。最重要的是,CKEditor 经过 10 年的不断完善和更新,其稳定性和兼容性已经不容质疑。

CKEditor--1.png

主要过程:

小兵用的是ZSSRichTextEditor HTML编辑器

1)利用UIWebView 内嵌HTML编辑器实现IOS下用户可以进行富文本编辑;主要目的是保证服务端的内容值不丢失.亦可在移动端对内容进行一些简单的修改.

ZSSRichTextEditor--3.png

2)加载本地的html文件


    [self.webView setUserInteractionEnabled:YES];//是否支持交互
    
    [self.webView setOpaque:NO];//opaque是不透明的意思
    [self.webView setScalesPageToFit:YES];//自动缩放以适应屏幕

   NSString* path = [[NSBundle mainBundle] pathForResource:@"11" ofType:@"html"];
    NSURL* url = [NSURL fileURLWithPath:path];
    
    //    NSString *str = @"http://192.168.5.120:7293/6.html";
    //    NSURL *url = [NSURL URLWithString:str];
    
    NSURLRequest* request = [NSURLRequest requestWithURL:url] ;
    [self.webView loadRequest:request];
    

3)在UIWebView的代理方法-(void)webViewDidFinishLoad:(UIWebView *)webView中提取html页面元素,跳转到编辑页面

-(void)webViewDidFinishLoad:(UIWebView *)_webView{
    
    NSLog(@"123");
    
    NSString *strings1 = [self.webView stringByEvaluatingJavaScriptFromString:@"document.body.innerHTML"];
   
    //    这里获得的strings为word文档内容的html格式。
//    NSLog(@"%@--askl",strings);
    
    indestr_body = [NSString stringWithFormat:@"<body>%@</body>",strings1];

4)提取HTML数据到编辑器

ZSSRichTextEditor--4.png

到此大功告成;

扩展:js与webview 常用交互代码


常用JS语句:::

1、 //禁用用户选择

    [self.webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.style.webkitUserSelect=‘none‘;"];

 

2、//禁用长按弹出框

    [webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.style.webkitTouchCallout=‘none‘;"];

 

3、//获得UIWebView的URL地址

NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];

NSLog(@"currentURL==%@",currentURL);

 

4、//获得UIWebView的标题

NSString *theTitle=[webView stringByEvaluatingJavaScriptFromString:@"document.title"];

NSLog(@"theTitle==%@",theTitle);

 

5、//通过name(获得/设置)页面元素的value值

    NSString *js_email_ByName = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByName(‘email‘)[0].value=‘hello‘;"];

    NSLog(@"js_email_ByName==%@",js_email_ByName);

NSString *js_password_ByName = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByName(‘pwd‘)[0].value=‘hello‘;"];

NSLog(@"js_password_ByName==%@",js_password_ByName);

    NSString *js_phone_ByName = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByName(‘tel‘)[0].value=‘hello‘;"];

NSLog(@"js_phone_ByName==%@",js_phone_ByName);

 

6、//通过id(获得/设置)页面元素的value值

NSString *js_email_ById = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementByIdx_x_x(‘_iphone_email‘).value=‘asdfasdf‘;"];

    NSLog(@"js_email_ById==%@",js_email_ById);

NSString *js_password_ById = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementByIdx_x_x(‘_iphone_pwd‘).value=‘asdfasdf‘;"];

    NSLog(@"js_password_ById==%@",js_password_ById);

NSString *js_phone_ById = [webView stringByEvaluatingJavaScriptFromString:@"document.getElementByIdx_x_x(‘_iphone_phone‘).value=‘asdfasdf‘;"];

     NSLog(@"js_phone_ById==%@",js_phone_ById);

 

7、//提交表单

    NSString *js_forms = [webView stringByEvaluatingJavaScriptFromString:@"document.forms[0].submit(); "];

    NSLog(@"js_forms==%@",js_forms);

   

8、//获得body与body之间的HTML

    NSString *allHTML = [webView stringByEvaluatingJavaScriptFromString:@"document.body.innerHTML"];

NSLog(@"allHTML: %@", allHTML);
9、//使UIWebView的输入框获得焦点(但是无法,弹出iphone键盘)

    [webView stringByEvaluatingJavaScriptFromString:@"document.querySelector(‘#saySome‘).focus()"];

    [webView stringByEvaluatingJavaScriptFromString:@"document.getElementByIdx_x("saySome").scrollIntoView("true")"];

 

10、//改变webview尺寸时对应改变web page尺寸(web page需要有对应的处理)

    [webview stringByEvaluatingJavaScriptFromString: [NSString stringWithFormat:@"document.querySelector(‘meta[name=viewport]‘).setAttribute(‘content‘, ‘width=%d;‘, false); ",(int)webview.frame.size.width]];

   

11、//获取webview显示内容的高度

    CGFloat documentWidth = [[wb stringByEvaluatingJavaScriptFromString:@"document.getElementById(‘content‘).offsetWidth"] floatValue];

CGFloat documentHeight = [[wb stringByEvaluatingJavaScriptFromString:@"document.getElementById(\"content\").offsetHeight;"] floatValue];

 

12、//通过id获取内容

    NSString *js = @"document.getElementById(‘lg‘).innerHTML";

    NSString *pageSource = [webView stringByEvaluatingJavaScriptFromString:js];

    NSLog(@"pagesource:%@", pageSource);

 

13、//改变字体大小

  [self.webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByTagName(‘body‘)[0].style.webkitTextSizeAdjust= ’150%’"];

 

14、//改变webView中图片大小

    [webView stringByEvaluatingJavaScriptFromString:

     @"var script = document.createElement(‘script‘);"

     "script.type = ‘text/javascript‘;"

     "script.text = \"function ResizeImages() { "

     "var myimg,oldwidth;"

     "var maxwidth = 300.0;" // UIWebView中显示的图片宽度

     "for(i=0;i <document.images.length;i++){"

     "myimg = document.images[i];"

     "if(myimg.width > maxwidth){"

     "oldwidth = myimg.width;"

     "myimg.width = maxwidth;"

     "}"

     "}"

     "}\";"

     "document.getElementsByTagName(‘head‘)[0].appendChild(script);"];

 

15、//删除所有链接

     [webView stringByEvaluatingJavaScriptFromString:@"$(document).ready(function () {$(\"a\").removeAttr(\"href\");})"];

 


强大的富文本,支持markdown语法

Demo


随手点个喜欢吧~

关注我

QQ--iOS 交流群:107548668

相关文章

网友评论

  • cf02d3bf4496:使用 ZSSRichTextEditor 可以通过审核吗?issues上面说有使用私有api
    沫若清风:@fay_ios 恩,好的,谢谢
    cf02d3bf4496:@沫若清风 有人项目里使用这个 上架成功了 应该是没问题的
    沫若清风:同问?
  • 白牛桑:
    你好,请问ZSSRichTextEditor在iOS10.3下有部分功能是不是已经不兼容了?
    操作场景:用系统键盘,先点击下划线按钮,输入中文(此时文字带有下划线,属于正常),接着点击下划线按钮,再次输入中文(此时文字仍然带有下划线,已经不正常了)。
    9e9ec8b27ad7:@短腿大书 取消已经样子,需在点击样式按钮后,可后面插入特殊字符如用‍进行分隔,中文字就显示正常了
    9413d0713da1:@白牛桑 你好,请问你这问题解决了吗
    f176ea1d3597:我也遇到这样的问题,只在10.3下会失效。试了其他App也是有同样的问题。
    应该不是ZSSRichTextEditor的问题,初步判定是系统WebView的Bug。
  • dong_liang:选取完照片后,点击export,卡好长时间控制台才会有输出,怎么改善呀这个
    小兵快跑:QQ 上说
  • c2fffd2b0090:我在使用过程中 当我选取相册照片的时候,就卡死,每次都这样 。请问这是什么情况啊
    c2fffd2b0090:@小兵快跑 你这说的太模糊了也 ,还有一个问题,可以添加多张照片啊?为什么只能一张呀
    小兵快跑:@打了鸡血 遇到过,内部处理一下
    c2fffd2b0090:又遇到吗?作者你好啊
  • c2fffd2b0090:最近要做这个,能否加个好友交流下下 大神 qq: 1736591423
    小兵快跑:到群里,明天白天在聊
  • 走停2015_iOS开发:我已经集成 但是键盘和webview的偏移量不协调,输入的文字被键盘挡住了
    请大神教我
    走停2015_iOS开发:@小兵快跑 好了 谢了
    小兵快跑:@走停2015_iOS开发 ZSSRichTextEditor内部更改
  • KKKKaras:编辑器里 换行 生成的html 仍然是 简单的字符 没有br之类的。如果有类似需求 该怎么入手
    KKKKaras:@小兵快跑 恩 看到了 我发现我用的是老版本的demo 以前的demo能满足我。后来通过改js解决了
    小兵快跑:@KKKKaras 你下载ZSSRichTextEditor Demo运行看看
  • 1b07faad76db:能不能发个demo
    小兵快跑:@阿西吧呢 晚上回去整理一个
  • a6d58425983d:能不能发个demo

本文标题:iOS开发--内嵌HTML编辑器 Objective-C 与 J

本文链接:https://www.haomeiwen.com/subject/sfwyettx.html