1

我一直在 wordpress 管理区域中设置我的插件。我有一个存储用户信息的表单。在我的文件输入类型中,我有对我链接到它的自定义 javascript 的 javascript 函数调用。这是行:<li>Category Image:<input type="file" name="category[image]" id="cat_image" onchange="javascript:ImageUpload()" /></li>。但是,它返回一个错误,说明 undefined function ImageUpload(),肯定无法找到该函数。我在想也许有一个wordpress函数可以调用这个,或者我需要先设置吗?但是我已经链接了我的自定义 js 并且它正在工作。问题是如何从管理区的wordpress php文件中调用某些js函数?我希望你们明白这一点。谢谢。这是我的代码:

插件文件.php

 <form method="post" name="new_category" id="product_category" enctype="multipart/form-data"> 
 <ul class="add_prod">
 <li>Category Title:<input type="text" name="category[title]" id="cat_title" value="" placeholder="Title" /> </li>
 <li>Category Description:<textarea rows="4" cols="40" name="category[description]"></textarea></li>
 <li>Category Image:<input type="file" name="category[image]" id="cat_image" onchange="javascript:ImageUpload()" /></li>
 <li><input type="submit" name="submit" id="submit" value="Submit details" class="btn-submit"/></li>
 </ul>  
 </form>

.js 文件:

function ImageUpload() {
    $("#return").show();
    $("#return").html('');
    $("#return").html('<img src="images/load2.gif" alt="Uploading...."/> wait, uploading...');
    $("#imageform").ajaxForm({
        target: '#return',
        success: function() {
            $("#return").fadeOut(10000);
        }
    }).submit();  

}

4

1 回答 1

1

确保您的 js 文件在被调用之前已加载。

你可以做这样的事情

<?php
    add_action('wp_head','js_call'); // make sure js is loaded in head

    function js_call() {  ?>
    <script>

    function ImageUpload() {
        jQuery("#return").show();
        jQuery("#return").html('');
        jQuery("#return").html('<img src="images/load2.gif" alt="Uploading...."/> wait, uploading...');
        jQuery("#imageform").ajaxForm({
            target: '#return',
            success: function() {
                jQuery("#return").fadeOut(10000);
            }
        }).submit(); 


    </script>

<?php    } ?>
于 2013-09-25T04:15:07.763 回答