乐于分享
好东西不私藏

文档对象模型与计时器函数

文档对象模型与计时器函数

本文介绍使用JavaScript对浏览器和页面编程的基本方法,包括BOM对象、DOM对象,以及计时器函数的应用。

BOMDOM

通过BOM(浏览器对象模式,Browser Object Model),可以对浏览器窗口、URL地址、导航、浏览历史、显示设备、页面内容等操作。其中,window对象表示浏览器窗口,是BOM中的主对象,其子对象包括:

  • document对象,表示页面对象,是DOM的主角,也就是说,DOMBOM的子集。

  • location对象,处理URL信息。

  • navigator对象,包含了浏览器信息。

  • history对象,控制浏览记录,如forward()方法为前进操作、back()方法为后退操作、go()方法指定前进(正数)或后退(负数)的浏览记录数量。

  • screen对象,包含了用户显示设备的信息。

实际应用中,随意修改浏览器外观和默认行为并不是好的设计方法,现代Web项目开发中几乎不再使用;本文接下来将主要讨论这些对象的常用操作。

页面节点

DOM(文档对象模型,Document Object Model)可以有效地处理HTMLXHTML等文档结构,下面先来看一个简单的HTML文件代码。

HTML

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

</head>

<body>

<div id="article">

<h1 id="title1">标题一</h1>

<p id="p1">段落一</p>

<p id="p2">段落二</p>

</div>

</body>

</html>

页面中的HTML元素一目了然,但现在需要了解页面中的“节点(node)”。在</html>标记后面添加如下代码。

JavaScript

<script>

let art = document.getElementById("article");

alert(art.childNodes.length);

</script>

即使还没有介绍代码中的doucment.getElementById()方法和art.childNodes.length属性,也应该可以大概猜出来这两行代码的功能是显示idarticlediv元素的子节点数量,显示结果为7。在HTML代码中可以看到,div元素下只有一个h1元素和两个元素,那么7个节点是从哪儿来的呢?请注意,在h1p元素的前后还有空白处,这里也是节点;这些节点不是元素,那它们是什么呢?

按下来,修改JavaScript代码如下。

JavaScript

<script>

let art = document.getElementById("article");

let node = art.childNodes[0];

alert(node.nodeName);

alert(node.nodeValue);

alert(node.nodeType);

</script>

代码中,使用art.childNodes[0]获取了div元素下的第一个子节点,然后显示了节点的三个属性,分别是:

  • nodeType属性,显示节点类型值,1ELEMENT_NODE)为页面元素,3TEXT_NODE)为文本节点,本例会显示3

  • nodeName属性,显示节点名称,本例显示为"#text"。如果是HTML元素,则会显示元素名的大写形式。

  • nodeValue属性,显示文本类节点的内容,非文本类节点返回null,本例为空白字符。DOM节点类型中,3TEXT_NODE)、4CDATA_NODE)、8COMMENT_NODE)为文本类型的节点。

art.childNodes[0]的索引值修改为1,可以看到h1元素的相关属性,会分别显示"H1"null1。可以看到,元素节点的nodeType返回1nodeName属性会返回元素名的大写形式,nodeValue属性返回null值。

从测试中可以看到,代码中定义的页面,从div元素以下的节点结构如下图所示。

##页面节点结构

虽然页面文档的结构是由各种节点组成,但在操作时一般会从一个确定的元素节点开始,下面就从元素节点的角度了解更多地操作。

获取和创建元素

获取元素时,可以使用document对象的以下方法和属性:

  • getElementById()方法,按元素的id属性值获取唯一的元素对象。

  • getElementsByClassName()方法,按元素的class属性值获取元素集合。

  • getElementsByName()方法,按元素的name属性值获取元素集合。

  • getElementsByTagName()方法,按元素类型名称获取元素集合,如所有P元素。

  • 元素集合属性,如images表示页面中所有img元素的集合,links表示页面中所包含href属性的a元素集合,forms表示页面中所有表单(from)元素的集合,embeds表示包含所有embed元素的集合等。

对于一个已获取的节点对象,常用的属性和方法包括:

  • parentNode属性,获取节点的上级节点。

  • hasChildNodes()方法,判断节点中是否有子节点,返回truefalse

  • firstChild属性,获取节点中的第一个子节点,没有子节点时返回undefined

  • lastChild属性,获取节点中的最后一个子节点,没有子节点时返回undefined

  • childNodes属性,返回节点中所有子节点的集合。

  • appendChild(node)方法,在节点中添加子节点node

  • insertBefore(x,y)方法,在节点的子节点y前插入子节点x

创建节点时可以使用document对象的如下方法:

  • createElement(elementName),根据元素名称创建元素节点。

  • createTextNode(text)方法,根据文本内容创建文本节点。

下面的代码会在“段落二”前添加“段落三”元素节点。

JavaScript

<script>

let p3 = document.createElement("p");

let p3Text = document.createTextNode("段落三");

p3.appendChild(p3Text);

let p2 = document.getElementById("p2");

let art = document.getElementById("article");

art.insertBefore(p3, p2);

</script>

运行代码,页面显示效果如下图所示。

##动态创建节点

利用p2元素的父节点也可以完成插入操作,如下面的代码。

JavaScript

<script>

let p3 = document.createElement("p");

let p3Text = document.createTextNode("段落三");

p3.appendChild(p3Text);

let p2 = document.getElementById("p2");

p2.parentNode.insertBefore(p3, p2);

</script>

执行结果与前例相同。

元素的innerHTMLinnerText属性

实际应用中,还可以使用innerHTMLinnerText属性修改元素中的HTML代码或文本内容。下面的代码演示了这两个属性的应用和区别。

JavaScript

<script>

let s = "X<sup>2</sup>";

let p1 = document.getElementById("p1");

let p2 = document.getElementById("p2");

p1.innerHTML = s;

p2.innerText = s;

</script>

代码中,变量s包含了一些HTML代码,内容为大写字母X和上标格式的数字2。接下来,通过innerHTML属性将s的内容设置到p1元素,通过innerText属性将s的内容设置到p2元素,页面显示效果如下图所示。

##元素的innerHTMLinnerText属性

可以看到,innerHTML属性内容会解析为HTML代码,而innerText属性内容则解析为文本内容。此外,还可以通过这两个属性读取元素中的HTML代码和文本内容。

读取和设置元素属性

读取元素的属性值时,可以使用元素对象的getAttribute()方法,其参数为属性名,如下面的代码会显示页面中第一个h1元素的id属性名。

JavaScript

<script>

let arr = document.getElementsByTagName("h1");

let e = arr[0];

alert(e.getAttribute("id"));

</script>

执行代码会显示"title1"

设置元素对象的属性值时可以使用元素对象的setAttribute()方法,参数分别是属性名和属性值,如下面的代码会设置第一个h1元素的style属性以改变其显示的样式。

JavaScript

<script>

let arr = document.getElementsByTagName("h1");

let e = arr[0];

e.setAttribute("style","font-style:italic;color:red;");

</script>

代码中设置第一个h1元素文本显示为斜体和红色,效果如下图所示。

##设置元素的style属性

可以通过元素对象的style属性中的样式属性设置元素样式,如下面的代码。

JavaScript

<script>

let arr = document.getElementsByTagName("h1");

let e = arr[0];

e.style.fontStyle = "italic";

e.style.color = "red";

</script>

代码执行效果与前例相同。

window对象

首先了解window对象的open()方法与close()方法,其中,open()方法用于打开新的浏览器窗口,其参数包括:

  • url,设置打开的资源路径。

  • target,设置资源的打开方式,默认为"_blank",指定在新的窗口或标签中打开;设置为"_self"时指定在当前窗口或标签打开。

  • features,可以通过一系列参数设置新窗口的外观,一般不需要使用。

  • replace,是否替换浏览器历史记录,默认为false

window.open()方法会返回一个窗口对象,而窗体对象的close()方法可以关闭窗口。下面的代码演示了相关应用。

HTML

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

</head>

<body>

<div id="article">

<button type="button" onclick="winOpen();">打开</button>

<button type="button" onclick="winClose();">关闭</button>

</div>

</body>

</html>

<script>

let win = null;

//

function winOpen() {

win = window.open("http://caohuayu.com");

}

//

function winClose() {

if (win === null) alert("没有可关闭的窗口");

else win.close();

}

</script>

页面中定义了两个按钮,其中,“打开”按钮会在新窗口或标签中打开作者的个人网站,回到初始页面,点击“关闭”按钮可以关闭打开的新网站窗口或标签。

此外,调用window对象的close()方法可以关闭当前窗口标签。

window对象的onload事件会在页面元素完全加载后触发,所以,这里是进行页面初始化工作的好地方,下面的代码演示了相关应用。

JavaScript

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

</head>

<body>

<h1   id="title1"></h1>

</body>

</html>

<script>

window.onload = function () {

document.getElementById("title1").innerText = "页面已加载";

};

</script>

本例,页面加载后会在h1元素中显示“页面已加载”。

有些时间,特别是在大型Web项目中,一个页面的初始化工作可能不止一次,此时就需要一个通用的机制能够正确地添加多个初始化函数,如下面的代码。

JavaScript

<script>

function addWinLoadFunc(fn) {

if (typeof fn !== "function") return;

let oldFn = window.onload;

window.onload = function () {

if (typeof oldFn ===   "function") oldFn();

fn();

};

}

//

function pageInit1() {

alert("初始化1");

}

//

addWinLoadFunc(pageInit1);

addWinLoadFunc(function () { alert("初始化2");   });

addWinLoadFunc(() => alert("初始化3"));

</script>

代码中首先定义了addWinLoadFunc()函数,参数fn指定为函数类型。addWinLoadFunc()函数中,当参数fn不是函数类型时会退出函数;然后,通过oldFn变量备份window.onload事件的原始代码;接下来定义window.onload事件执行的新函数,其中,当onload原始代码为函数时先调用它,最后调用fn指定的函数,这样就保证了初始化代码的执行顺序。

pageInit1()函数为第一个初始化函数,第一次调用addWinLoadFunc()函数时直接使用函数名作为参数;第二次调用addWinLoadFunc()函数时使用了匿名函数;第三次调用addWinLoadFunc()函数时使用了=>运算符创建的简化函数。打开页面,会依次显示"初始化1""初始化2""初始化3"

URL与文本编码

location对象可以处理地址栏显示的URL地址信息,常用的属性包括:

  • href属性,获取地址栏显示的完整的URL地址。

  • hosthostname,获取URL中的服务器主机名称。

  • pathname属性,获取服务器中的资源路径。

  • port属性,获取URL中的服务器端口。

  • protocol属性,获取URL中使用的协议,如http:https:

  • search属性,获取问号(?)及以后的查询参数。

  • hash属性,获取#符号及以后的内容。

下面的代码会显示相关的属性值,请注意,打开测试页面后可以在网址的最后手动添加"?name=Tom&age=25"

JavaScript

<script>

alert(location.href); //   http://localhost:58476/demo/test.html?name=Tom&age=25

alert(location.host); // localhost:58476

alert(location.pathname);//   /demo/test.html

alert(location.port);// 58476

alert(location.protocol);//   http:

alert(location.search);//   ?name=Tom&age=25

</script>

处理问号(?)后面的参数时,可删除问号,然后使用&符号分割成数组,数组中的每一个元素就是“参数名=值”的格式,需要再次使用等号(=)分割为参数名和值。下面的代码可以将URL中的查询参数转换为Map对象。

JavaScript

<script>

function getQueryParam() {

let result = new Map();

let s = location.search;

if (s.length === 0) return result;

let arr = s.substring(1).split(/&/g);

let kvArr;

for (let kv of arr) {

kvArr = kv.split("=");

result.set(kvArr[0], kvArr[1]);

}

return result;

}

//

let qryParam = getQueryParam();

qryParam.forEach((v, k) => alert(k + " : " + v));

</script>

本例,如果访问网址为“http://localhost:58476/demo/test.html?name=Tom&age=25”,则会依次显示"name : Tom""age : 25"。代码中,getQueryParam()函数会返回一个Map对象,如果URL中没有查询参数,则返回一个没有元素的空集合。

需要注意的是,URL地址在传递过程中可能会进行编码处理,此时,可以使用以下函数进行处理:

  • encodeURI()decodeURI()函数,对URL进行编码和解码操作,不处理的字符包括字母、数字,以及字符# - _ . ! ~ * ' ( ) ; , / ? : @ & = + $

  • encodeURIComponent()decodeURIComponent()函数,对URL进行编码和解码操作,不处理的字符包括字母、数字,以及字符( ) . ! ~ * ' - _

计时器函数

setTimeount()函数需要指定两个参数,其中,参数一指定执行的函数,参数二指定等待多少毫秒以后开始执行;函数会返回一个计时器标识,可以使用clearTimeout()函数终止指定标识的计时器代码。需要注意的是,setTimeout()指定的函数只会执行一次,如果需要再次执行,需要重复调用setTimeout()函数,下面的代码演示了相关应用。

HTML

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

</head>

<body>

<h1 id="title1"></h1>

<button type="button"   onclick="clearTimeout(timerFlag);">停止</button>

</body>

</html>

<script>

let timerFlag = null;

function showTime() {

let h1 = document.getElementById("title1");

h1.innerText = new Date().toLocaleTimeString();

timerFlag = setTimeout(showTime, 1000);

}

//

showTime();

</script>

JavaScript代码中,timerFlag变量会保存最后一次调用setTimeout()函数的计时器标识,showTime()函数中,会将系统当前时间显示到h1元素中,每隔1秒更新一次。点击页面中的“停止”按钮后,会调用clearTimeout()函数停止时间的更新。

setInterval()函数的第一个参数同样指定执行函数,第二个参数指定每次执行的间隔毫秒数,与setTimeout()函数不同的是,setInterval()函数会严格地按照指定的时间间隔重复执行代码;此外,setInterval()函数同样会返回一个计时器标识,可以使用clearInterval()函数终止指定标识的计时器代码。下面的代码演示了setInterval()clearInterval()函数的应用。

HTML

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<title></title>

</head>

<body>

<h1 id="title1"></h1>

<button type="button"   onclick="clearTimeout(timerFlag);">停止</button>

</body>

</html>

<script>

function showTime() {

let h1 = document.getElementById("title1");

h1.innerText = new Date().toLocaleTimeString();

}

//

showTime();

let timerFlag = setInterval(showTime, 1000);

</script>

代码功能与前例相同,打开页面后会在h1元素中显示系统当前时间,点击“停止”按钮后会停止时间更新。

setTimeout()函数调用的代码会在每次执行完成后再按指定的间隔时间执行,可以保证每次代码执行的完整性,适用于每次执行代码都需要完整性和正确性的场景。而setInterval()则会保证在指定间隔时间时准时开始执行新的代码,即使上一次代码还没有执行完成也是这样,典型的情况可以参考游戏循环,以执行的时效性为主;但是,如果一个循环没有完成就开始下一循环,就可能出现“跳帧”的情况。实际应用中,可以根据执行代码的性质和功能需要合理选择合适的计时器函数。

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-06-16 23:50:45 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/750172.html
  2. 运行时间 : 0.229709s [ 吞吐率:4.35req/s ] 内存消耗:4,782.57kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=1d959505f632050c232384463124394e
  1. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_static.php ( 6.05 KB )
  7. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/ralouphie/getallheaders/src/getallheaders.php ( 1.60 KB )
  10. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  11. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  12. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  13. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  14. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  15. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  16. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  17. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  18. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  19. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions_include.php ( 0.16 KB )
  21. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions.php ( 5.54 KB )
  22. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  23. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  24. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  25. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/provider.php ( 0.19 KB )
  26. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  27. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  28. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  29. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/common.php ( 0.03 KB )
  30. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  32. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/alipay.php ( 3.59 KB )
  33. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  34. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/app.php ( 0.95 KB )
  35. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cache.php ( 0.78 KB )
  36. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/console.php ( 0.23 KB )
  37. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cookie.php ( 0.56 KB )
  38. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/database.php ( 2.48 KB )
  39. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/filesystem.php ( 0.61 KB )
  40. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/lang.php ( 0.91 KB )
  41. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/log.php ( 1.35 KB )
  42. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/middleware.php ( 0.19 KB )
  43. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/route.php ( 1.89 KB )
  44. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/session.php ( 0.57 KB )
  45. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/trace.php ( 0.34 KB )
  46. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/view.php ( 0.82 KB )
  47. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/event.php ( 0.25 KB )
  48. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  49. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/service.php ( 0.13 KB )
  50. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/AppService.php ( 0.26 KB )
  51. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  52. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  53. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  54. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  55. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  56. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/services.php ( 0.14 KB )
  57. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  58. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  59. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  60. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  61. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  62. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  63. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  64. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  65. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  66. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  67. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  68. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  69. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  70. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  71. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  72. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  73. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  74. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  75. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  76. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  77. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  78. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  79. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  80. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  81. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  82. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  83. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  84. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  85. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  86. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  87. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/Request.php ( 0.09 KB )
  88. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  89. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/middleware.php ( 0.25 KB )
  90. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  91. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  92. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  93. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  94. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  95. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  96. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  97. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  98. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  99. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  100. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  101. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  102. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  103. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/route/app.php ( 3.94 KB )
  104. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  105. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  106. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Index.php ( 9.87 KB )
  108. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/BaseController.php ( 2.05 KB )
  109. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  110. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  111. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  112. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  113. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  114. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  115. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  116. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  117. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  118. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  119. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  120. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  121. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  122. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  123. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  124. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  125. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  126. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  127. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  128. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  129. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  130. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  131. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  132. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  133. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  134. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  135. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Es.php ( 3.30 KB )
  136. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  137. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  138. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  139. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  140. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  141. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  142. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  143. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  144. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/runtime/temp/c935550e3e8a3a4c27dd94e439343fdf.php ( 31.50 KB )
  145. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.001081s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001627s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.001774s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.006552s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001494s ]
  6. SELECT * FROM `set` [ RunTime:0.001628s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001553s ]
  8. SELECT * FROM `article` WHERE `id` = 750172 LIMIT 1 [ RunTime:0.009917s ]
  9. UPDATE `article` SET `lasttime` = 1781625045 WHERE `id` = 750172 [ RunTime:0.003615s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000693s ]
  11. SELECT * FROM `article` WHERE `id` < 750172 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001385s ]
  12. SELECT * FROM `article` WHERE `id` > 750172 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001200s ]
  13. SELECT * FROM `article` WHERE `id` < 750172 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001948s ]
  14. SELECT * FROM `article` WHERE `id` < 750172 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.018915s ]
  15. SELECT * FROM `article` WHERE `id` < 750172 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.024763s ]
0.231459s