- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
自从过去 2 年以来,我在 cordova 中的工作有 2 个副本,并且工作正常,没有任何错误。
在这两个副本中,只有特定于平台的更改。意味着在 Windows Phone 中它不允许加载 html 文件所以我将所有 html 文件添加到脚本标签中并加载到主 index.html 中以使其正常工作并且它在 Windows Phone 中工作并且在第二个副本中我制作了普通的 html 文件分开,因为 android 和 ios 没有加载外部 html 文件的问题。
所以我的问题是:有什么方法可以将所有代码合并到一个副本中,并且具有相同 www 文件夹的代码也可以在 android、ios 和 windows phone 中运行?
根据我的经验,这可能是不可能的,因为 Windows Phone 的文件结构与 Android/iOS 不同。
如果有人知道所有平台的一些通用解决方法,请提供指导。
最佳答案
您可以使用 Cordova CLI 中的“合并”功能来执行此操作。假设我有一个如下所示的项目:
-rw-r--r-- 1 simon 员工 1115 Mar 22 19:57 config.xml
drwxr-xr-x 3 simon staff 102 Mar 17 21:47 hooks/
drwxr-xr-x 7 simon staff 238 Mar 22 19:57 platforms/
drwxr-xr-x 7 simon staff 238 Mar 22 19:57 插件/
drwxr-xr-x 7 simon staff 238 Mar 21 13:11 www/
我的应用程序代码都在 www 中,组织如下:
drwxr-xr-x 4 simon staff 136 Mar 24 12:42 css/
drwxr-xr-x 4 simon 员工 136 Mar 21 13:11 img/
-rw-r--r-- 1 西蒙工作人员 1338 年 3 月 21 日 15:16 index.html
drwxr-xr-x 4 simon 员工 136 Mar 22 18:29 js/
想象一下,我同时安装了 Android 和 iOS 平台,并且想在每个平台上做一些不同的事情,而不是放置很多:
如果 (device.platform === 'Android') {
//Android 特定代码
} 别的 {
//特定于 iOS,假设我们只支持 iOS
}
我的应用程序中的一些代码。这也无法扩展到许多平台(例如,在其中添加 Windows 和 BB,然后每次都有更多的 if/else 或 switch 语句)。
为此,Cordova 的 CLI 可以合并代码,并将查找名为 merges 的顶级文件夹。因此,在您的 config.xml 所在的同一文件夹中创建其中一个,因此项目现在看起来像:
-rw-r--r-- 1 simon 员工 1115 Mar 22 19:57 config.xml
drwxr-xr-x 3 simon staff 102 Mar 17 21:47 hooks/
drwxr-xr-x 4 simon staff 136 Mar 22 17:47 merges/
drwxr-xr-x 7 simon staff 238 Mar 22 19:57 platforms/
drwxr-xr-x 7 simon staff 238 Mar 22 19:57 插件/
drwxr-xr-x 7 simon staff 238 Mar 21 13:11 www/
然后创建:
合并/机器人
合并/ios
您放入其中的任何内容都将被复制到平台特定的 www 文件夹中,并覆盖与您的主 www 文件夹相同路径中的内容,或者如果 www 中没有相同名称/路径的内容,则会被添加。
例子:
ls -lF 合并/android/img
共 16 个
-rw--------@ 1 simon staff 7626 Mar 21 13:23 logo.png
此图像 logo.png 将替换 www/img/logo.png,仅适用于 Android。我可以为 iOS 做同样的事情(添加 merges/ios/img/logo.png)或者使用默认图像(www/img/logo.png)。
这可以针对您在平台特定基础上需要的任何类型的文件(JS/CSS/img/JSON/其他)完成。
无需编写 Hook 脚本即可完成这项工作,当您为每个平台运行 cordova build 时,CLI 会自动执行此操作。
有关此概念的文档在 Cordova CLI docs 中.
关于android - cordova 中所有平台的通用 www 文件夹和所有文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36792696/
我使用plugman命令在cordova中创建了一个插件 它创建了所有必需的文件。然后我在插件中添加了android平台。 然后我尝试将它添加到 cordova 应用程序中。我成功添加了它,但是当我尝
我使用plugman命令在cordova中创建了一个插件 它创建了所有必需的文件。然后我在插件中添加了android平台。 然后我尝试将它添加到 cordova 应用程序中。我成功添加了它,但是当我尝
我正在尝试在较旧的 Atrix 上安装一个应用程序,在 S3 上运行良好。搜索论坛可能的问题是SDK版本较高(Atrix是4.0.4)。修复显然是在设置 API 级别。 但是当我运行 cordova
使用 cordova build在一个为期一年的项目中提出: :processDebugResources my_project/platforms/android/build/intermediat
我有一个可以创建文件的可运行应用程序。 我正在寻找一种工作后数小时从cordova应用程序中删除文件的方法。我似乎无法使其正常工作。 这是用于创建和删除文件的代码: function crea
有什么区别吗Cordova 构建 Android 和 Cordova 准备 Android 命令? Reference is added here 最佳答案 准备将您的 www Assets 和任何插
我检查了文档,但没有找到关于此命令的明确说明。 那么,有谁知道cordova prepare命令的作用是什么? 是否更新特定于平台的www文件夹? 如果是,它将复制根www的全部内容吗? 它会更新平台
我们正在开发正在使用Cordova(专用于Ionic)的移动应用程序,并且正在使用PhoneGap PushPlugin和Amazon SNS进行推送通知。反过来,这会撞到我们与Amazon SNS进
我正在使用Vue,Webpack和Cordova。 Videos 如果我在没有Cordova的情况下加载页面,并且在Firefox浏览器中,则可以使用Youtube视频上的全屏图
因此,我尝试在我的(正在运行的)Ionic应用程序中安装一个新插件,该文件名为https://ionicframework.com/docs/native/firebase-dynamic-links
我像这样安装了cordova: C:\Windows\system32>npm install -g cordova 我明白了: C:\Users\cyril\AppData\Roaming\npm\
我有一个 cordova 应用程序,我使用以下代码捕获了后退按钮: document.addEventListener("backbutton", function (e) { bac
如何在 Cordova 中的蓝牙设备和 Android/iOS 之间发送和接收一系列数据字节? 我的项目的详细信息: 我正在开发一个蓝牙传感器设备。设备以一系列字节的形式发送数据。它还对设备 API
我是 cordova 开发的新手。我使用 Onsen UI (1.2.1) 作为布局框架。ons-toolbar 上的标题有问题。 someTextHere 如果我在 ripple 上运行
我有一个启用了平台浏览器的 Cordova 应用程序。我想在 Chrome 中使用摄像头,但调用摄像头根本没有任何反馈。它在我的 Android 设备上就像一个魅力。 我通过这个命令启动:cordov
我对thid docs https://firebase.google.com/docs/android/setup#available_libraries中提到的根级和应用程序级的路径目录感到困惑
喜欢这些插件 https://github.com/ArchieGoodwin/SilentShot https://github.com/alongubkin/phonertc 他们没有 tarba
我有一个 Angular 2 应用程序,我正在将其构建到 cordova 中并部署到 Android/IOS。我没有使用 ionic,我见过许多使用 ionic 的解决方案,但我现在无法将整个项目转换
当我发出命令时,在带有 Cordova 的 Ionic 3 中: ionic cordova run android --emulate 它给出以下消息: BUILD FAILED in 3s
我无法在 ionic 5.2.4v 中安装软件包 cordova-res 并收到以下错误。 命令:cordova-res C:\hanu\cordova-res-master\cordova-res
我是一名优秀的程序员,十分优秀!