php 设置报错等级

本文介绍了PHP中的error_reporting函数,详细解释了如何通过设置不同的错误级别来控制错误报告,并提供了具体的示例代码。

定义和用法:
    error_reporting() 设置 PHP 的报错级别并返回当前级别。

函数语法:
    error_reporting(report_level)

如果参数 level 未指定,当前报错级别将被返回。下面几项是 level 可能的值:
    值     常量                  描述
        E_ERROR               致命的运行错误。错误无法恢复,暂停执行脚本。
        E_WARNING             运行时警告(非致命性错误)。非致命的运行错误,脚本执行不会停止。
        E_PARSE               编译时解析错误。解析错误只由分析器产生。
        E_NOTICE              运行时提醒(这些经常是你代码中的bug引起的,也可能是有意的行为造成的。)
    16     E_CORE_ERROR          PHP启动时初始化过程中的致命错误。
    32     E_CORE_WARNING        PHP启动时初始化过程中的警告(非致命性错)。
    64     E_COMPILE_ERROR       编译时致命性错。这就像由Zend脚本引擎生成了一个E_ERROR。
    128    E_COMPILE_WARNING     编译时警告(非致命性错)。这就像由Zend脚本引擎生成了一个E_WARNING警告。
    256    E_USER_ERROR          用户自定义的错误消息。这就像由使用PHP函数trigger_error(程序员设置E_ERROR)
    512    E_USER_WARNING        用户自定义的警告消息。这就像由使用PHP函数trigger_error(程序员设定的一个E_WARNING警告)
    1024   E_USER_NOTICE         用户自定义的提醒消息。这就像一个由使用PHP函数trigger_error(程序员一个E_NOTICE集)
    2048   E_STRICT              编码标准化警告。允许PHP建议如何修改代码以确保最佳的互操作性向前兼容性。
    4096   E_RECOVERABLE_ERROR   开捕致命错误。这就像一个E_ERROR,但可以通过用户定义的处理捕获(又见set_error_handler())
    8191   E_ALL                 所有的错误和警告(不包括 E_STRICT) (E_STRICT will be part of E_ALL as of PHP 6.0)

例子:
    任意数目的以上选项都可以用“或”来连接(用 OR 或 |),这样可以报告所有需要的各级别错误。
    例如,下面的代码关闭了用户自定义的错误和警告,执行了某些操作,然后恢复到原始的报错级别:

    <?php
    //禁用错误报告
    error_reporting(0);
   
    //报告运行时错误
    error_reporting(E_ERROR | E_WARNING | E_PARSE);
   
    //报告所有错误
    error_reporting(E_ALL);
    ?>

一个简单的例子是:

error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);

他表示php错误,警告,语法错误,提醒都返错。

在 Vue 模板中,如果你写了类似下面的内容: ```html <span style="font-weight: 700">owner: &nbsp</span> ``` 并遇到了如下报错: ``` Parsing error: missing-semicolon-after-character-reference ``` 这是由于你在 HTML 模板中使用了 HTML 实体 `&nbsp` 但没有以正确的方式书写它。HTML 中的字符实体必须以 `&` 开头,以 `;` 结尾。所以 `&nbsp` 应该写成 ` `。 ### 正确写法 ```html <span style="font-weight: 700">owner:  </span> ``` ### 报错原因解释 - `&nbsp` 被解析器识别为字符实体的开始,但因为没有分号 `;`,解析器就认为你漏掉了 `;`。 - 这个错误在 Vue 的模板编译阶段由 HTML 解析器(如 `htmlparser2` 或 Vue 自带的模板解析器)抛出。 - Vue 模板本质上是 HTML 的超集,因此它遵循 HTML 的语法规则。 --- ### 其他等价写法 你也可以使用以下方式避免错误: #### 方法一:使用原生空格字符(推荐) ```html <span style="font-weight: 700">owner: </span> ``` 你可以直接输入一个空格字符,或者多个空格,它们在 HTML 中会被合并为一个空格。如果你希望保留多个空格,可以使用 CSS 的 `white-space` 属性。 #### 方法二:使用 Vue 的 `v-html`(不推荐用于静态文本) ```html <span style="font-weight: 700" v-html="'owner:  '"></span> ``` 但这种方式会带来 XSS 风险,除非你确实需要动态插入 HTML,否则不推荐使用。 --- ### 补充说明 - ` ` 是 HTML 中的“不可断行的空格”(non-breaking space)。 - 所有 HTML 实体都应以 `&` 开头,以 `;` 结尾,例如 `<`、`>`、`&` 等。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值