为什么php与JS代码合并时换行符被过滤掉?

栏目:建站技术 2025-09-06

原始php文件结构:(注意<?php require '_nodetype_setother.js';?>与“});”之间是有换行的)

$("input[name=nodetype]").click(function(){

  var name = $("#name").val();

  var nodetype = $(this).val();

  <?php require '_nodetype_setother.js';?>

});


插入的JS文件内容:(注意下面的代码的最后一行是没有空行的)

var input_width = $("input:text[name='width']");

var input_height = $("input:text[name='height']");

input_width.val('');

input_height.val('');


最后运行的php文件的源代码如下:

$("input[name=nodetype]").click(function(){

  var name = $("#name").val();

  var nodetype = $(this).val();

  var input_width = $("input:text[name='width']");

var input_height = $("input:text[name='height']");

input_width.val('');

input_height.val('');});


有没有发现在原始php文件结构中的最后一行的“});”与“input_height.val('');”怎么到了一行去了?在原php文件中“});”与<?php require '_nodetype_setother.js';?>是存在换行的,那么为什么之前存在换行的而最后得到的源代码中却没有了换行了呢?


这个问题涉及到 PHP 的 require 机制和服务器端与客户端代码执行的差异。

1:PHP require 是服务器端操作:

<?php require '_nodetype_setother.js';?> 在服务器端执行

服务器会读取 _nodetype_setother.js 文件的内容并将其直接插入到 PHP 代码的位置

这个过程发生在发送给浏览器之前

2:文件结尾的处理:

如果 _nodetype_setother.js 文件的最后没有空行,那么插入的内容会紧挨着后面的 });

浏览器接收到的最终代码就是合并后的结果


解决方案:

1:在 JS 文件末尾添加空行:即在 _nodetype_setother.js 文件末尾添加一个空行,确保插入后有换行

2:修改 PHP 代码添加换行:?php echo " "; ?>


注意除了会过滤掉换行,同时还会过滤掉空格,比如<?php require '_nodetype_setother.js';?>前面存在的空格,在发送到浏览器之后这个空格就不见了。


相关阅读

中英文混和的字符串的ASCII与UNICODE编码与解码

2020-10-10184

//1:获取中英文混合字符的编码(ASCII码与UNICODE码)$str=&quot;官网制作:网巢网络&quot;;foreach(math($str)as$key=&gt;$value){if(preg_match(&#39;/^[x{4e00}-x{9fa5}]+$/u&#39;,$value)){//中文,注意中文这里暂时不转换,因为无法通过chr…

正则表达式收集汇总

2020-12-1285

搜索:empty(($)tr[&#39;([a-z]{1,})&#39;]),可以查找这样的empty($tr[&#39;digest&#39;]),然后可以替换成!$digest替换:!$1$2匹配A标签的超连接的正则表式如下$pattern=&quot;/&lt;a[^&gt;]+?href=[&quot;&#39;]?([^&quot;&#39;]+)…

手机访问电脑网时自动跳转代码

2020-10-1087

4G降临,移动网站已经一发不可收拾,pc端和移动端官网并存。如何让别人访问你的pc端的官网直接跳转到移动端的网站呢?各位看官,小二上代码!来了!varurl=window.location.href;varurl_match=/vit=1$/i;if(!url.match(url_match)){if(navigator.userAgent.match(/(…

如何让你的PHP网站变得更安全

2020-10-1082

安全配置一(1)打开php的安全模式php的安全模式是个非常重要的内嵌的安全机制,能够控制一些php中的函数,比如system(),同时把很多文件操作函数进行了权限控制,也不允许对某些关键文件的文件,比如/etc/passwd,但是默认的php.ini是没有打开安全模式的,我们把它打开:safe_mode=on(2)用户组安全当safe_mode打开时,sa…

小程序的下单与支付的业务流程

2020-10-10221

1:小程序携带商品信息调用第三方服务器的下单API2:第三方服务器下单API对小程序带来的商品作库存量检测3:如果检测通过,第三方服务器就会保存这个订单并且告之小程序下单成功4:小程序调用第三方服务器的支付api5:第三方服务器API调用微信的预订单API[WxPayApi::unifiedOrder](注意第三方服务器是无法完成支付的,这个订单实际是在微信…

如何解决QQ显示未启用的问题

2024-08-8247

没设置临时会话,一般都会出现下面的状况。QQ放在网站上作为客服,必须设置临时会话。或者点击之后,要求加为好友才可以对话。解决这个问题的步骤如下:一、登陆腾讯官方网站:http://wp.qq.com/二、登陆之后,点“设置”,按下图所示,全部打勾。这个必须设置,不设置,不能临时会话,就会显示“未启用”。这一步是关键,必须设置。(1)先看服务有没被停用:如停用…