http://blog.csdn.net/e20914053/article/details/50170487

如今混合开发方兴未艾,有的项目可能一开始是原生开发的,后期需要加入混合开发,如将Cordova工程引进到原生工程中。那么该如何操作呢?下面就来描述一下步骤。

1、首先我们来创建一个Cordova工程,取名MyCordova。在创建Cordova工程之前,需要先安装Cordova,具体安装方法网上很多,在此不累述。

  1. cordova create MyCordova

进入MyCordova工程目录,其结构如下:

2、接下来添加iOS平台,添加命令如下:

  1. cordova platform add ios

该命令需要在MyCordova工程根目录下执行。执行成功后,我们进入MyCordova工程下的platforms目录下,我们发现它增加了一个名为ios的文件目录。

3、回到MyCordova工程根目录,运行刚才添加的ios工程。

  1. cordova run ios

运行效果如下:

4、通过xcode创建一个原生工程MyApp。如果原生工程已经存在,可以忽略此步骤。

5、将MyCordova工程中iOS下的CordovaLib文件夹和www文件夹拷贝到MyApp工程目录下。

MyCordova目录:

MyApp目录:

6、参看上图。删除CordovaLib下面的build文件夹,此文件夹是在执行cordova run
ios命令过程中产生的,如果你没有执行过该命令就不会产生这个文件夹。然后通过xcode的Add files to “MyApp”
...将CordovaLib.xcodeproj文件和www文件夹添加到MyApp工程中。注意,在添加www文件夹时要勾选Create
folder references。如下:

7、将MyCordova工程根目录下的config.xml也添加到MyApp工程中。至此,所需的文件拷贝添加工作已经完成,其文件结构如下:

下面开始对对MyApp工程进行配置工作。

8、选择MyApp工程的Build Settings->Other Linker Flags, 设置-Objc -all_load

9、选择MyApp工程的Build Phases->Target Dependencies添加CordovaLib

10、选择MyApp工程的Build Phases->Link Binary With Librarys添加libCordova.a、 MobileCoreServices.framework、AssetsLibrary.framework相关框架。

到此MyApp工程已经顺利导入MyCordova工程了,点击Product->Build编译通过。下面再来创建并弹出Cordova页面。

11、创建一个视图控制器CordovaViewController。

其中CordovaViewController.h文件内容如下:

  1. #import <Cordova/CDVViewController.h>
  2. #import <Cordova/CDVCommandDelegateImpl.h>
  3. #import <Cordova/CDVCommandQueue.h>
  4. @interface CordovaViewController : CDVViewController
  5. @end
  6. @interface CordovaCommandDelegate : CDVCommandDelegateImpl
  7. @end
  8. @interface CordovaCommandQueue : CDVCommandQueue
  9. @end

CordovaViewController.m文件内容如下:

  1. #import "CordovaViewController.h"
  2. @implementation CordovaViewController
  3. - (id)initWithNibName:(NSString*)nibNameOrNil bundle:(NSBundle*)nibBundleOrNil
  4. {
  5. self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
  6. if (self) {
  7. // Uncomment to override the CDVCommandDelegateImpl used
  8. // _commandDelegate = [[MainCommandDelegate alloc] initWithViewController:self];
  9. // Uncomment to override the CDVCommandQueue used
  10. // _commandQueue = [[MainCommandQueue alloc] initWithViewController:self];
  11. }
  12. return self;
  13. }
  14. - (id)init
  15. {
  16. self = [super init];
  17. if (self) {
  18. // Uncomment to override the CDVCommandDelegateImpl used
  19. // _commandDelegate = [[MainCommandDelegate alloc] initWithViewController:self];
  20. // Uncomment to override the CDVCommandQueue used
  21. // _commandQueue = [[MainCommandQueue alloc] initWithViewController:self];
  22. }
  23. return self;
  24. }
  25. - (void)didReceiveMemoryWarning
  26. {
  27. [super didReceiveMemoryWarning];
  28. }
  29. #pragma mark View lifecycle
  30. - (void)viewWillAppear:(BOOL)animated
  31. {
  32. [super viewWillAppear:animated];
  33. }
  34. - (void)viewDidLoad
  35. {
  36. [super viewDidLoad];
  37. }
  38. - (void)viewDidUnload
  39. {
  40. [super viewDidUnload];
  41. }
  42. #pragma mark UIWebDelegate implementation
  43. - (void)webViewDidFinishLoad:(UIWebView*)theWebView
  44. {
  45. theWebView.backgroundColor = [UIColor blackColor];
  46. return [super webViewDidFinishLoad:theWebView];
  47. }
  48. @end
  49. @implementation CordovaCommandDelegate
  50. #pragma mark CDVCommandDelegate implementation
  51. - (id)getCommandInstance:(NSString*)className
  52. {
  53. return [super getCommandInstance:className];
  54. }
  55. - (NSString*)pathForResource:(NSString*)resourcepath
  56. {
  57. return [super pathForResource:resourcepath];
  58. }
  59. @end
  60. @implementation CordovaCommandQueue
  61. - (BOOL)execute:(CDVInvokedUrlCommand*)command
  62. {
  63. return [super execute:command];
  64. }
  65. @end

12、为MyApp工程中的“进入Cordova”UIButton绑定事件方法,来弹出CordovaViewController视图控制器。运行效果如下:(左边为原生视图控制器,右边为弹出的CordovaViewController视图控制器)

                        

是不是跟在MyCordova工程中通过cordova run ios命令运行出来的效果一样呢!

ok,至此原生工程导入Cordova工程的方法步骤全部结束。

如何在原生工程中引入Cordova工程-for iOS 【转】的更多相关文章

  1. maven ----> 子工程中引入父工程

    创建父工程,打包方式指定为 pom <groupId>com.example</groupId> <artifactId>SleuthMain</artifa ...

  2. vue-cli 工程中引入jquery

    在vue-cli 生成的工程中引入了jquery,记录一下.(模板用的webpack) 首先在package.json里的dependencies加入"jquery" : &quo ...

  3. [转载]android工程中引入另一个工程中的资源

    原文地址:android工程中引入另一个工程中的资源作者:87fayuan 在项目中可能遇到这样的问题:项目过大,于是细分为N个子模块来做,每个模块都是不同的工程.涉及到activity传数据时,可以 ...

  4. 测试工程中引入Masonry记录

    测试工程中需要引入Masonry,在进行添加新库时发现了几个问题,记录如下,方便有相同问题的朋友查找解决:   1,podfile中添加 pod ‘Masonry’ 后,pod install --v ...

  5. 现有工程中集成Cordova

    cocoapods引入cordova源码 1.依赖Cordova和wk插件 pod 'Cordova' pod 'cordova-plugin-wkwebview-engine' 建立Cordova支 ...

  6. 【idea】idea如何在maven工程中引入jar包

    在pom.xml文件中引入所有代码包后,项目右键--maven--reimport </dependencies>

  7. MFC在一个工程中启动其他工程的exe文件

    说明:有的时候把两个工程合并,但是偷懒不想在工程中添加代码,所以想到了这个办法,仅限偷懒哈哈哈哈 方法:新建一个主程序,在主程序的界面中添加按钮,在按钮的程序代码中添加以下语句: void CMain ...

  8. 在Web工程中引入Jquery插件报错解决方案

    在学习Jquery插件的时候,遇到一个问题就是新建web工程后在WebRoot下引入Jquery插件的时候报错,不知道为什么好纠结,但是项目能正常运行,后来找到解决方案,在这里给大家分享一下. 解决方 ...

  9. 如何在 Maven 工程中引入其他jar包 并生效?(以 Netty 为例)

    1.到 Maven 官网  查找 相关 框架 https://mvnrepository.com/artifact/io.netty/netty-all/4.1.32.Final 2.把相关 Xml体 ...

随机推荐

  1. Codeforces Round #372 (Div. 1) A. Plus and Square Root 数学题

    A. Plus and Square Root 题目连接: http://codeforces.com/contest/715/problem/A Description ZS the Coder i ...

  2. spring boot 集成 shiro

    写在前面 1.Shiro是Apache下的一个开源项目,我们称之为Apache Shiro.它是一个很易用与Java项目的的安全框架,提供了认证.授权.加密.会话管理,与spring Security ...

  3. FireDAC 下的 Sqlite [5] - 数据的插入、更新、删除

    先在空白窗体上添加: TFDConnection.TFDPhysSQLiteDriverLink.TFDGUIxWaitCursor.TFDQuery.TDataSource.TDBGrid(并在设计 ...

  4. WebService使用实例

    近期刚刚開始学习使用WebService的方法进行server端数据交互,发现网上的资料不是非常全, 眼下就结合收集到的一些资料做了一个小样例和大家分享一下~ 我们在PC机器javaclient中.须 ...

  5. [Asp.net mvc]Html.ValidationSummary(bool)

    摘要 对ValidationSummary是HtmlHelper的扩展方法,用来返回 System.Web.Mvc.ModelStateDictionary (即ModelState)对象中的验证消息 ...

  6. 安装APK的错误码(PackageManager.java)

    安装APK的错误码,定义在android源码中的这个文件中:frameworks\base\core\java\android\content\pm\PackageManager.java /** * ...

  7. ASP.NET Web API基于OData的增删改查,以及处理实体间关系

    本篇体验实现ASP.NET Web API基于OData的增删改查,以及处理实体间的关系. 首先是比较典型的一对多关系,Supplier和Product. public class Product { ...

  8. concat函數 函數concat 可以用來合拼兩個或以上的字串。

    12. “Mexico 墨西哥”的首都是”Mexico City”. 顯示所有國家名字,其首都是國家名字加上”City”. concat函數 函數concat 可以用來合拼兩個或以上的字串. : SE ...

  9. Android Service总结04 之被绑定的服务 -- Bound Service

    Android Service总结04 之被绑定的服务 -- Bound Service 版本 版本说明 发布时间 发布人 V1.0 添加了Service的介绍和示例 2013-03-17 Skywa ...

  10. SugarCRM 插件介绍

    [转自 陈沙克日志:http://hi.baidu.com/chenshake/item/5d76203fe6a598fede22219d]经常有朋友问关于sugar的插件,我这里就整理一下,不过其实 ...