Bagusflyer
Bagusflyer

Reputation: 12925

iOS loadHtmlString in UIWebView doesn't work with Javascript

I have a iOS app to load a html string which refer to external css file and javascript file in the same directory.

Here is my html file:

<html>
<head>
    <meta name="viewport" content= user-scalable="no", width="device-width" />
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8"/> 
    <link rel="stylesheet" type="text/css" href="mystyle.css" />
    <script type="text/javascript" src="myjavascript.js"></script>
</head>

The css file works fine but it seems the js file never loaded. What could be the reason?

By the way I'm using loadHtmlString: BaseUrl method to load my html string.

Thanks

Upvotes: 9

Views: 7193

Answers (3)

Kevin Borders
Kevin Borders

Reputation: 2992

By default, xcode will put new Javascript files in Compile Resources instead of Bundle Resources. Click on your project, then on your target. Under 'Build Phases' you may see the Javascript files under 'Compile Sources'. Drag them to down to 'Copy Bundle Resources'.

Upvotes: 5

angel of code
angel of code

Reputation: 686

like the others have said

  • use baseURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] bundlePath]]];

  • copy Bundle Resources and not in Compile Resources.

thats it!

Upvotes: 2

sergio
sergio

Reputation: 69047

This question is a bit old, but since it has not been answered, I would like to point out that if you would like your web view to load a javascript file residing in your bundle, the way to do it is:

[webView loadHTMLString:html
               baseURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] bundlePath]]];

If you don't specify the baseURL there is no chance that the javascript file is loaded.

Upvotes: 7

Related Questions