How can i call javaScript function in iOS Swift

2019-07-14 08:59发布

问题:

i am trying to get html string from a web view. i try to get html string from web view like,

let html = webView.stringByEvaluatingJavaScript(from: "document.documentElement.outerHTML")
print(html)

in this code i get all Html code without the input value what i given after web loading. on the other hand there is function which that will give me full html code with input value. but i was unable to call javascript function in my swift code.also my javaScript function have a parameter which one i want to call.

i was try to call javaSript function like this,

let pp = webView.stringByEvaluatingJavaScript(from:"draft")

But its not working. i want to get all of html including input value.

Here is a Screenshot how it's done in android.

i was attach all of my html code here

<!DOCTYPE html>
<html lang='en'>
    <head>
        <meta http-equiv='Content-Type' content='text/html charset=UTF-8'/>
        <link type='text/css' rel='stylesheet' href='file:///android_asset/bootstrap.min.css'>
        <script src="file:///android_asset/jquery.min.js"></script> 
        <title>Quick Inspection</title>
        <style>
            textarea{
                resize: none;
            }
        </style>
    </head>
    <body style='background: #fff3d6'>
        <div class='container-fluid' style='padding-top: 10px; padding-left: 0px; padding-right: 0px; background: #fff3d6'>
            <div class='container'>
                <div class='row'>
                    <form id='rendered-form'>
                        <div class='rendered-form'>
                            <div class='fb-textarea form-group field-textarea-1505524302868'>
                                <label for='textarea-1505524302868' class='fb-textarea-label'>1. Description of Work</label>
                                <textarea class='form-control textarea' name='textarea-1505524302868' id='textarea-1505524302868'></textarea>
                            </div>
                            <div class='fb-textarea form-group field-textarea-1505524384468'>
                                <label for='textarea-1505524384468' class='fb-textarea-label'>2. Work Status</label>
                                <textarea class='form-control textarea' name='textarea-1505524384468' id='textarea-1505524384468'></textarea>
                            </div>
                            <div class='fb-textarea form-group field-textarea-1505524405168'>
                                <label for='textarea-1505524405168' class='fb-textarea-label'>3. Progress</label>
                                <textarea class='form-control textarea' name='textarea-1505524405168' id='textarea-1505524405168'></textarea>
                            </div>
                            <div class='fb-textarea form-group field-textarea-1505524418785'>
                                    <label for='textarea-1505524418785' class='fb-textarea-label'>4. Observation</label>
                                <textarea class='form-control textarea' name='textarea-1505524418785' id='textarea-1505524418785'></textarea>
                            </div>
                            <div class='fb-textarea form-group field-textarea-1505524433458'>
                                <label for='textarea-1505524433458' class='fb-textarea-label'>5. Recommendation</label>
                                <textarea class='form-control textarea' name='textarea-1505524433458' id='textarea-1505524433458'></textarea>
                            </div>
                        </div>
                    </form>
                </div>
            </div>
            <div class="clearfix"></div>
        </div>
        <div id="jsonvalue" style="visibility: hidden; display:inline;"></div>
    </body>

<script>

var getJsonData = $("#jsonvalue").text();
if(getJsonData != ""){
    SetJsonValue();
}

function getHtml()
{
    var Alldata = $('form').serializeArray();
    var JsonString = JSON.stringify(Alldata);
    $("div#jsonvalue").text(JsonString);
    var allCode = document.documentElement.outerHTML;
    return allCode;
}


function SetJsonValue()
{
    var getJsonData = $("#jsonvalue").text();
    var obj = $.parseJSON(getJsonData), dataObj = {};
    len = obj.length;
    for (i = 0; i < len; i++) {
        var f_name = obj[i].name;
        var f_value = obj[i].value;
        var result = f_name.split('-');
        var type = result[0];
        if (type == 'textarea') {
            $("#rendered-form " + type + "[name = " + f_name + "]").text(f_value);
        } else if (type == 'text') {
            $("input[name = " + f_name + "]").val(f_value);
        } else if (type == 'radio') {
            $('#rendered-form input[name=' + f_name + '][value=' + f_value + ']').prop("checked", true);
        } else if (type == 'select') {
            $("#rendered-form " + type + "[name = " + f_name + "]").val(f_value);
        } else {
            $(":checkbox[value=" + f_value + "]").prop("checked","true");
        }
    }
}


function draft(){
     var getAllHtmlCode = getHtml();
     Android.fullCode(getAllHtmlCode);
}

function finalsave(){
    var obj = $('form').serializeArray();
    len = obj.length;
    //$( ".fb-radio-group").hide();
    for (i = 0; i < len; i++) {
        var f_name = obj[i].name;
        var f_value = obj[i].value;
        var result = f_name.split('-');
        var type = result[0];
        if (type == 'textarea') {
            //if( f_value == "") {
            //  $( ".field-textarea-"+result[1]).hide();
            //}else{
                var bodyText = f_value;
                var body = $("<div class='ans'> </div>");
                body.text(bodyText);
                $("#rendered-form " + type + "[name = " + f_name + "]").replaceWith(body);
            //}
        } else if (type == 'text') {
            //if( f_value == "") {
            //  $( ".field-text-"+result[1]).hide();
            //}else{
                var bodyText = f_value;
                var body = $("<div class='ans'> </div>");
                body.text(bodyText);
                $("input[name = " + f_name + "]").replaceWith(body);
            //}
        } else if (type == 'radio') {
            //$(".l_header").hide();
            //$(".field-radio-group-"+result[2]).prev().show();
            //$(".field-radio-group-"+result[2]).show();
            var r_value = $('#rendered-form input[name=' + f_name + ']:checked').val();
            $('#rendered-form input[name=' + f_name + ']').parent().hide();
            $("label[for='"+f_name+"']").append('<div class="ans">'+r_value+'</div>');
        } else if (type == 'select') {
            if( f_value == "" || f_value == "0") {
                //$( ".field-select-"+result[1]).hide();
            }else{
                var lbl = $("#rendered-form " + type + "[name = " + f_name + "]").find('option:selected').text();
                var body = $("<div class='ans'> </div>");
                body.text(lbl);
                $("#rendered-form " + type + "[name = " + f_name + "]").replaceWith(body);
            }
        } else {
            $(":checkbox[value=" + f_value + "]").prop("checked","true");
        }
    }
    var allCode = document.getElementById("rendered-form").outerHTML;
    Android.finalCode(allCode);
}
</script>

</html>