doutan8601 2016-02-19 18:21
浏览 32
已采纳

表单的PHP错误[关闭]

I want to keep my div layout to my site when being directed with my error codes. Thing is I don't want multiple errors to have two separate css/div layouts. Here's what I got so far:

if(!preg_match($email_exp,$email_from)) {
  $error_message .= '<font color="blue">The Email Address you entered does not appear to be valid.<br /></font>';
}

$string_exp = "/^[A-Za-z .'-]+$/";

if(!preg_match($string_exp,$first_name)) {
  $error_message .= 'The First Name you entered does not appear to be valid.<br />';
}

if(!preg_match($string_exp,$last_name)) {
  $error_message .= 'The Last Name you entered does not appear to be valid.<br />';
}

if(strlen($comments) < 2) {
  $error_message .= 'The Comments you entered do not appear to be valid.<br />';

I want them all to open up on a page and have the same layout. If there are more than one errors, I want them to not each have separate code. How do I do that?

  • 写回答

1条回答 默认 最新

  • douchao0358 2016-02-19 18:29
    关注

    So I think you're asking for a single div to show any errors, something like this:

    <div id="errors">
        <?php echo (!empty($error_message) ? $error_message : ""); ?>
    </div>
    

    But if you want the errors to show up on the same page as the form, you're far better off doing that in Javascript. Put something like this on your page:

    <form>
        Sample: <input id="sample" type="text" onKeyUp="validateInputs()">
        <button type="button">Button Text</button>
    </form>
    <div id="error-div"></div>
    
    <script>
        function validateInputs() {
        var errorMessage = '';
        var sampleText = document.getElementById('sample').value;
        if( !sampleText || sampleText.length < 4 ) {
            errorMessage = 'input "Sample" must be as least 4 chars in length';
        }
        if( errorMessage.length > 0 ) {
            document.getElementById('error-div').innerHTML = errorMessage;
        } else {
            document.getElementById('error-div').innerHTML = 'no errors';   
        }
      }
    </script>
    

    Here's a working jsfiddle example.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 使用Java milo连接Kepserver服务端报错?
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?
  • ¥20 软件开发方法学习来了
  • ¥15 微信小程序商城如何实现多商户收款 平台分润抽成
  • ¥15 HC32L176调试了一个通过TIMER5+DMA驱动WS2812B
  • ¥15 cocos的js代码调用wx.createUseInfoButton问题!
  • ¥15 关于自相关函数法和周期图法实现对随机信号的功率谱估计的matlab程序运行的问题,请各位专家解答!