Emre Önder
Emre Önder

Reputation: 2537

WkWebView Evaluatejavascript returns unsupported type error

I'm sending a value to javascript function and get a result. However, I'm getting "Error Domain=WKErrorDomain Code=5 "JavaScript execution returned a result of an unsupported type" UserInfo={NSLocalizedDescription=JavaScript execution returned a result of an unsupported type}" error when run below code;

webView?.evaluateJavaScript("getURL()") { (result, error) in
            if let error = error
            {
                print("\(error)");
                return
            }
            if let song = result as? String
            {
                print("\(song)");
            }
        }

and javascript code as follows;

    function getURL(){
  CloudKit.configure({
                         containers: [{
                                      // To use your own container, replace containerIdentifier and apiToken
                                      containerIdentifier: 'iCloud.com.hello.myapp',
                                      apiToken: 'myApiKey',
                                      environment: 'development'
                                      }]
                         });
                         console.log("cloudkitloaded");

                         var self = this;
                         console.log("get default container");
                         var container = CloudKit.getDefaultContainer();

                         console.log("set publicDB");
                         var publicDB = container.publicCloudDatabase;
                         self.items = ko.observableArray();

                         // Fetch public records
                         //  self.fetchRecords = function() {
                         console.log("fetching records from " + publicDB);
                         var query = { recordType: 'Musics'};

                         // Execute the query.
                         return publicDB.performQuery(query).then(function(response) {
                                                                  if(response.hasErrors) {
                                                                  console.error(response.errors[0]);
                                                                  return;
                                                                  }
                                                                  var records = response.records;
                                                                  var numberOfRecords = records.length;
                                                                  if (numberOfRecords === 0) {
                                                                  console.error('No matching items');
                                                                  return;
                                                                  }

                                                                  console.log(records.length + " records")
                                                                  //console.log(records[0].fields.Song_File.value.downloadURL);
                                                                  self.items(records);


                                                                  myVar = records[emre].fields.Song_File.value.downloadURL;
                                                                  document.getElementById('someId').innerHTML = myVar;


                                                                  });
                                                                  return "emre";

  };

Upvotes: 26

Views: 19551

Answers (3)

yycking
yycking

Reputation: 1311

use anonymous functions

webView.evaluateJavaScript("""
    (function() {
        getURL();
    })();
""") 

Upvotes: 8

mackworth
mackworth

Reputation: 5953

I ran into same thing, and search brought me here. Later, I found the answer:

This is probably due to returning nil from your javascript, which is then reported as an error. Only a string is allowed to be returned. So just changing those return statements to return '' or return 'error msg' should fix it.

Upvotes: 9

Dhiroo Verma
Dhiroo Verma

Reputation: 618

Try to wrap your javascript code into setTimeout:

webView?.evaluateJavaScript("setTimeout(function() {getURL()}, 1000);")

Upvotes: 10

Related Questions