Using .html, .js file saved in the sandbox(Documents directory) of an iOS App so that I am able to open the html file in offline mode as well(使用保存在 iOS 应用程序的沙箱(文档目录)中的 .html、.js 文件,这样我也可以在离线模式下打开 html 文件) - IT屋-程序员软件开发技术分享社
问题描述
我必须显示一个需要 highcharts.js、jquery.min.js 的 .html 文件才能显示图表.我打算在 UIWebView 中显示 .html 文件.
I have to display an .html file which needs highcharts.js, jquery.min.js in order to display a graph. I am planning to display the .html file in a UIWebView.
我看到当文件(即 html、highcharts.js、jquery.min)在 Application Bundle 中时,我可以像这样使用它们--
I saw that when the files(i.e. html, highcharts.js, jquery.min) are in the Application Bundle, I can use them like this--
aPath = [[NSBundle mainBundle] pathForResource:@"htmlfile" ofType:@"html"];[self.graphWebView loadRequest:[NSURLRequest requestWithURL:[NSURL fileURLWithPath:aPath isDirectory:NO]]];
这里,htmlFile"的来源是这样的 -
Here, the "htmlFile" has the source like this -
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>TITLE</title>
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="highcharts.js"></script>
<script type="text/javascript" src="htmlfile.js"></script>
<script type="text/javascript" src="global.js"></script>
</head>
<body>
<div id="wrapper">
<div id="container"></div>
</div>
</body>
</html>
所以,为了在 UIWebView 中显示内容,我只需在 Xcode 的 Build Phases 选项卡中将 .html 文件和 .js 文件制作为 Bundle Resources.
So, in order to display the content in UIWebView, i just needed to make the .html file and .js files as Bundle Resources in Xcode's Build Phases Tab.
问题:
如上图所示源的.html文件保存在App的沙盒中时如何显示?
How do display the .html file having the source like shown above when It is saved in the App's Sand Box?
我试过了:
1.我像这样在App SandBox中创建了一个文件夹--
1. I created a folder in the App SandBox like this--
NSArray *paths =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,是的);
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) ;
NSString aFolderPath = [(NSString)[paths objectAtIndex:0] stringByAppendingFormat:@"/%@",@"folder"];
NSString aFolderPath = [(NSString)[paths objectAtIndex:0] stringByAppendingFormat:@"/%@",@"folder"];
if(![[NSFileManager defaultManager] isWritableFileAtPath:aFolderPath]){
[[NSFileManager defaultManager]createDirectoryAtPath:aFolderPath withIntermediateDirectories:NO attributes:nil error:nil];}
[[NSFileManager defaultManager]createDirectoryAtPath:aFolderPath withIntermediateDirectories:NO attributes:nil error:nil]; }
2.然后我像这样从App Bundle中复制了App SandBox中的html,js文件--
2. Then I copied the html, js files in the App SandBox from the App Bundle like this--
NSString *aJs = [[NSBundle mainBundle] pathForResource:@"JSFile"ofType:@"js"];
NSString *aJs = [[NSBundle mainBundle] pathForResource:@"JSFile" ofType:@"js"];
aJs = [NSString stringWithContentsOfFile:aGlobaljs encoding:NSUTF8StringEncoding error:nil];
NSString *aPath = [(NSString*)[paths objectAtIndex:0] stringByAppendingFormat:@"/folder/%@",@"JSFile.js"];
[aJs writeToFile:aPath atomically:YES encoding:NSUTF8StringEncoding error:nil];
现在所有需要的文件都在名为文件夹"的沙盒文件夹中,所以,我尝试像这样在 UIWebView 中打开保存的 html 文件--
Now all the needed files are in the SandBox Folder named "folder", so, I tried to open the saved html file in the UIWebView like this--
[self.webView loadRequest:[NSURLRequest requestWithURL:[NSURLURLWithString:pathToHtmlFileinDocumentsDic relativeToURL:[NSURLURLWithString:aFolderPath]]]];
[self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:pathToHtmlFileinDocumentsDic relativeToURL:[NSURL URLWithString:aFolderPath]]]];
这不起作用.
推荐答案
您必须将文件保存在您的应用程序资源中,这里的技巧是保持 JavaScript 文件与 HTML 文件的相对链接.添加 html 包时,选择为任何添加的文件夹创建文件夹引用".并在代码中像这样调用您的 html 页面:
You will have to keep your files in your apps resources, the trick here is to maintain the relative linking of the JavaScript files with the HTML files. When adding your html package select "Create folder reference for any added folders". and call your html page like this in code:
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html" inDirectory:@"Help"];
NSURL *indexUrl = [NSURL fileURLWithPath:filePath];
您的所有 Html 页面(包括 css
、images
、js
)都位于 Help(或您拥有的任何其他名称)文件夹中.即,它就像在文件夹中维护一个本地静态站点
Where all your Html pages (including css
, images
, js
) are in Help (or any other name you have) folder. i.e., its like maintaining a local static site inside the folder
这篇关于使用保存在 iOS 应用程序的沙箱(文档目录)中的 .html、.js 文件,这样我也可以在离线模式下打开 html 文件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用保存在 iOS 应用程序的沙箱(文档目录)中的 .html、.js 文件,这样我也可以在离线模式下打开 html 文件
基础教程推荐
- android 应用程序已发布,但在 google play 中找不到 2022-01-01
- Android:对话框关闭而不调用关闭 2022-01-01
- UIWebView 委托方法 shouldStartLoadWithRequest:在 WKWebView 中等效? 2022-01-01
- Kivy Buildozer 无法构建 apk,命令失败:./distribute.sh -m “kivy"d 2022-01-01
- 如何让对象对 Cocos2D 中的触摸做出反应? 2022-01-01
- 在 gmail 中为 ios 应用程序检索朋友的朋友 2022-01-01
- 如何在 iPhone 上显示来自 API 的 HTML 文本? 2022-01-01
- 如何在 UIImageView 中异步加载图像? 2022-01-01
- 如何在没有IB的情况下将2个按钮添加到右侧的UINavigationbar? 2022-01-01
- 当从同一个组件调用时,两个 IBAction 触发的顺序是什么? 2022-01-01