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

所属栏目:建站技术 更新时间:2025-09-06 点击: 文章来源:/jzjs/10698.html

原始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';?>前面存在的空格,在发送到浏览器之后这个空格就不见了。


相关阅读

用火狐打开百度一直加载s1.bdstatic.com的解决办法

一直用火狐浏览器,火狐浏览器插件多,很合适网页开发人员使用,以前一直用的好好的,但是今天使用的时候突然发现没有以前好用了,打开百度的官网一直很卡,通过FIREBGU发现在打开百度官网的时候一直会加载s1.bdstatic.com这个网站,无语,怎么打开百度的官网还需要链接s1.bdstatic.com这个网站这个网站吗?难道是百度被黑了,或者是自己的浏览器被…

了解详情 >>

正则表达式收集汇总

搜索: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;]+)…

了解详情 >>

如何解决网站上传大文件的问题?

为了服务器的网络安全,避免因为超大文件导致服务器故障,所以对文件上传的大小限制是很有必要的,但是有些客户又有上传大文件的需求,比如上传pdf或者压缩包这种格式的文件,那么碰到这种情况下,如何解决这个问题呢?在浏览器输出phpinfo();查看LoadedConfigurationFile这个参数可以获取php.info的文件位置1:如果上传的文件太大,会导致…

了解详情 >>

小程序倒计时wxml与js

小程序倒计时jsPage({data:{windowHeight:654,maxtime:&quot;&quot;,isHiddenLoading:true,isHiddenToast:true,dataList:{},countDownDay:0,countDownHour:0,countDownMinute:0,countDownSecond:0,},/…

了解详情 >>

小程序列表多个批量倒计时

Page({onShow(){letthat=this;vardates={datetime:[{dat:0,name:&#39;zs&#39;},{dat:6,name:&#39;ls&#39;},{dat:10,name:&#39;ww&#39;}]}//console.log(dates)//数据letlen=dates.datetime.length…

了解详情 >>

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

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

了解详情 >>

Copyright @ 2008-2019   www.sznest.net   All rights reserved  网巢网是一家专业为企业提供免费建站、自助建站的模板建站公司     友情链接:

微信

移动端

客服

顶部