-5
// Add an additional field to the checkout within a new fieldset
add_filter('eshopaddtocheckout','eshop_extras_checkout');

function eshop_extras_checkout($echo){

$echo .= '  <script>
        jQuery(function($) {
            $(".formGroup").hide();
            $("#chooseForm input:checkbox").on("change", function() {
                if($(this).is(":checked")) {
                    $("#" + $(this).val()).show();
                }
                else {
                    $("#" + $(this).val()).hide();
                }
            });
        });

    </script>';



    $echo .= '<fieldset class="eshop eshop_extra">' . "\n";


    $echo .= '<legend>Select the Approriate Form</legend>' . "\n";

    $echo .= ' <div id="chooseForm">
        <input type="checkbox" name="forms2[]" id="ArticlesOrderForm" value="ArticlesOrderForm"> <b>Articles Order Form </b><br>
        <input type="checkbox" name="forms2[]" id="PressReleasesForm"  value="PressReleasesForm"> <b> Press Releases Form </b><br>
    </div>

    <div id="ArticlesOrderForm" class="formGroup">
        <legend>Articles Order Form</legend>
        <label for="kwd1">Art-Keywords1</label><input class="short" type="text" name="kwd1" value="" id="kwd1" maxlength="20" size="20" > <br>

    </div>

    <div id="PressReleasesForm" class="formGroup">
        <legend>Press Releases Form</legend>
        <label for="kwd2">PRKeywords2</label><input class="short" type="text" name="kwd2" value="" id="kwd2" maxlength="20" size="20"> <br>
    </div>';


 $echo .= '<fieldset class="eshop eshop_extra">' . "\n";

    $echo .= '<legend>Extras</legend>' . "\n";
    $echo .= '<label for="eshop_extra">'.__('Extra Field','eshop').' <span class="reqd">*</span><br />
          <input class="short" type="text" name="eshop_extra" value="" id="eshop_extra" maxlength="20" size="20" /></label><br />';
    $echo .= '</fieldset>' . "\n";

    return $echo;
}



  // Add extra field to error checks
    add_filter('eshoperrorcheckout','eshop_extras_errorcheckout');
    function eshop_extras_errorcheckout($_POST){
        $myerror='';

        if(!isset($_POST['eshop_extra']) || trim($_POST['eshop_extra'])==''){
        $myerror= '<li>'.__('<strong>Extra Field</strong> - missing.','eshop_extras').'</li>';
    }



    if(!isset($_POST['ArticlesOrderForm'])) {

      if(!isset($_POST['kwd1']) || trim($_POST['kwd1'])=='') {
        $myerror= '<li>'.__('<strong>KWD1</strong> - missing.','kwd1').'</li>';
        }
    }


    if(!isset($_POST['PressReleasesForm'])) {

      if(!isset($_POST['kwd2']) || trim($_POST['kwd2'])=='') {
        $myerror= '<li>'.__('<strong>KWD2</strong> - missing.','kwd2').'</li>';
        }
    }   


        return $myerror;
    }

** 现在我没有收到任何语法错误....请检查下面的链接:(在选择适当的形式下),当您检查它们时,它们丢失了..我做错了什么..?**

articlewritingservicess.com/shopping-cart/checkout/

4

1 回答 1

5

您正在混淆服务器端代码和客户端代码。

PHP 在服务器上使用,并将生成发送到浏览器的 HTML(该 HTML 可以包括 jquery)。但是 jquery 只能在浏览器上运行。

问题是您在服务器端使用 jquery 命令,并带有以下行... (这是您函数
中的第二条if语句)eshop_extras_errorcheckout

if($('#check_id').is(":checked"))

这应该是 PHP 代码,而不是 jquery ......类似......

if(isset($_POST('check_id'))){
  // Do something
}

附加基于OP的评论

您的复选框在页面回发时没有保持“选中”的原因是因为您<input type="checkbox"每次都在创建代码,并且如果您没有专门提供该checked属性,那么在页面显示时它将被取消选中。

(我不确定您是否熟悉 ASP.NET,但在该技术中,如果您勾选复选框然后回发,ASP.NET 将为您处理此问题。PHP 不作为标准执行此操作,您需要告诉它检查它。)

因此,例如,您在函数中“回显”以下行eshop_extras_checkout(注意,这包含在 PHP 字符串中,它不是直接标记):

<input type="checkbox" name="forms2[]" id="ArticlesOrderForm"
  value="ArticlesOrderForm"> <b>Articles Order Form </b><br>

...您需要有条件地放置checked属性,如下所示:

(isset($_POST('ArticlesOrderForm')) ? "Checked" : "")

...这将导致字符串看起来像

<input type="checkbox" name="forms2[]" id="ArticlesOrderForm" 
  value="ArticlesOrderForm" ' . (isset($_POST('ArticlesOrderForm')) ? "Checked" : "") . '> <b>Articles Order Form </b><br>

因此,当最终的 HTML 发送到浏览器时,checked如果复选框被选中,该属性将出现,如果不选中则不会出现。

希望这是有道理的

于 2012-10-22T15:49:50.487 回答