• 为员工创造价值,为客户创造价值;
  • 为推动全社会进步而努力;
  • 成为中国的企业IT人才培养解决方案提供商.

400-689-2779

React前端开发全流程解析:从基础概念到实战部署的系统指南

React前端开发全流程解析:从基础概念到实战部署的系统指南

授课机构: 南京柯普瑞IT学校

上课地点: 校区地址

成交/评价:

联系电话: 400-689-2779

React前端开发全流程解析:从基础概念到实战部署的系统指南课程详情

基础概念:React的核心定位与技术特性

作为现代前端开发的主流框架之一,React的出现彻底改变了复杂UI的构建方式。它由Facebook(现Meta)团队开发并开源,本质上是一个用于构建用户界面的JavaScript库。区别于传统DOM操作,React通过虚拟DOM(Virtual DOM)机制实现高效的UI更新,仅在数据变化时计算最小DOM差异,极大提升了页面渲染性能。

从功能维度看,React提供了组件化开发模式、声明式编程范式及跨平台能力(通过React Native可开发移动端应用)。其核心优势体现在:

  • 组件化:将UI拆分为独立可复用的组件,降低代码耦合度
  • 声明式:只需描述"想要的界面",React自动处理DOM更新逻辑
  • 生态丰富:拥有Redux、React Router等配套工具,覆盖全场景开发需求

当然,React也存在一定局限性。例如,其本身仅负责视图层,需要结合其他库(如Redux)实现状态管理;对于小型项目,引入React可能增加技术栈复杂度;此外,JSX语法对传统HTML开发者有一定学习门槛。

关于开发环境搭建,建议使用Node.js 14.x以上版本,通过npm或yarn安装React。基础命令为:npx create-react-app my-app,该命令会自动生成包含Babel(转译ES6+语法)和Webpack(模块打包)的标准化项目结构。

语法工具:JSX的使用规范与实践技巧

JSX(JavaScript XML)是React推荐的语法扩展,允许在JavaScript中直接编写类似HTML的结构。它并非强制使用(可通过createElement手动创建元素),但能显著提升代码可读性和开发效率。

使用JSX时需注意:

  1. 元素必须闭合:单标签如img需写成<img src="" />
  2. 属性命名规范:采用小驼峰式(如className代替class,htmlFor代替for)
  3. 表达式嵌入:使用大括号{}插入JavaScript变量或函数调用

嵌套元素的编写需遵循严格的结构规则,每个JSX片段只能有一个根元素(可通过<></>空标签包裹多个元素)。例如:

function App() {
  return (
    <>
      <h1>Hello World</h1>
      <p>This is a React component</p>
    </>
  );
}

样式处理方面,React推荐使用内联样式对象(需用双大括号包裹)或CSS-in-JS方案(如styled-components)。例如:<div style={{ color: 'red', fontSize: '16px' }}>文本内容</div>

注释需包裹在大括号内,语法为{/* 注释内容 */},注意避免在JSX顶层直接使用HTML注释<!-- -->

组件开发:生命周期与状态管理核心

组件是React应用的基本单元,分为类组件(Class Component)和函数组件(Function Component)。随着Hooks(如useState、useEffect)的引入,函数组件已成为主流开发模式,因其更简洁的语法和更灵活的逻辑复用能力。

组件生命周期在类组件中体现为一系列预定义方法,典型流程包括:

  • 挂载阶段:constructor → render → componentDidMount(用于初始化数据请求)
  • 更新阶段:shouldComponentUpdate(性能优化) → render → componentDidUpdate
  • 卸载阶段:componentWillUnmount(清理定时器、事件监听器)

事件处理需注意React的合成事件(Synthetic Event)机制,它对原生DOM事件进行了封装,提供统一的跨浏览器兼容性。事件处理函数需通过props传递给子组件,常见写法如:

<button onClick={handleClick}>点击按钮</button>

组件通信是开发中的高频需求,主要分为三种场景:

父→子通信
通过props传递数据或函数
子→父通信
父组件传递回调函数给子组件,子组件调用时携带参数
兄弟组件通信
通过共同父组件作为中介,或使用全局状态管理方案(如Redux)

props验证可通过PropTypes库(需单独安装)或TypeScript实现,确保组件接收数据的类型正确性,例如:

import PropTypes from 'prop-types';
Component.propTypes = {
  name: PropTypes.string.isRequired,
  age: PropTypes.number
};

状态管理:Redux的核心原理与实战应用

当应用复杂度提升时,组件间共享状态的管理变得尤为关键。Redux作为React生态中最常用的状态管理库,基于Flux架构思想,通过单一数据源(Store)和纯函数reducer实现可预测的状态变更。

Redux的三大核心原则是:

  1. 单一数据源:整个应用的状态存储在一个Store对象中,便于追踪和调试
  2. 状态是只读的:唯一改变状态的方式是发送Action(一个描述"发生了什么"的普通对象)
  3. 使用纯函数执行修改:Reducer((state, action) => newState)必须是无副作用的纯函数

集成react-redux时,需通过Provider组件将Store提供给整个应用,并使用connect函数(或更简洁的useSelector/useDispatch Hooks)将组件与Store连接。典型项目结构建议:

src/
  store/
    index.js       # Store配置
    actions/       # Action创建函数
    reducers/      # Reducer函数
    types.js       # Action类型常量

Action是状态变更的触发器,通常包含type字段和payload数据。Reducer负责根据Action返回新的状态,需注意不可直接修改原state对象,应返回新对象。Store通过createStore函数创建,可结合中间件(如redux-thunk处理异步Action)增强功能。

表单与事件:受控与非受控组件的选择策略

表单处理是前端开发的常见需求,React中将表单元素分为受控组件(Controlled Component)和非受控组件(Uncontrolled Component)。

受控组件的value属性由React状态(state)控制,用户输入会触发状态更新,从而实现数据与UI的同步。典型示例:

function InputDemo() {
  const [value, setValue] = useState('');
  const handleChange = (e) => setValue(e.target.value);
  return <input value={value} onChange={handleChange} />;
}

非受控组件则通过ref直接访问DOM元素获取值,适用于不需要实时验证或初始值由DOM决定的场景(如文件上传)。需注意ref的使用需通过useRef Hook(函数组件)或createRef(类组件)创建。

事件句柄的创建需注意绑定this(类组件)或使用箭头函数避免作用域问题。子组件事件通常通过props向上传递,例如父组件定义处理函数,子组件通过props接收并在事件触发时调用。

路由实现:React Router的配置与项目实践

单页应用(SPA)的页面切换依赖前端路由管理,React Router是官方推荐的路由库,提供BrowserRouter(基于HTML5 History API)和HashRouter(基于URL哈希)两种模式。

基础安装命令为:npm install react-router-dom。核心组件包括:

  • Router:包裹整个应用的根组件(如BrowserRouter)
  • Route:定义路径与组件的映射关系,支持path、component、render等属性
  • Link:用于导航的组件,类似HTML的a标签,但不会触发页面刷新
  • Switch:匹配个符合条件的Route(用于避免多路由同时匹配)

路径匹配支持动态参数(如/user/:id),可通过useParams Hook获取参数值。嵌套路由通过在子组件中再次使用Route实现,需注意父组件需包含<Outlet />(v6版本)作为子路由渲染位置。

实际项目中,建议将路由配置抽离为独立文件,便于维护。例如:

const routes = [
  { path: '/', element: <Home /> },
  { path: '/about', element: <About /> },
  { path: '/user/:id', element: <UserDetail /> }
];

通过useNavigate Hook可实现编程式导航,例如:

const navigate = useNavigate();
navigate('/about');

构建工具:Webpack的配置优化与脚手架搭建

Webpack作为前端模块打包工具,能将JavaScript、CSS、图片等资源转换为浏览器可识别的格式。React项目通常通过create-react-app初始化,其内置了Webpack配置,但实际开发中常需自定义调整。

基础配置文件(webpack.config.js)需定义入口(entry)、输出(output)、模块规则(module.rules)和插件(plugins)。例如处理CSS文件需配置style-loader和css-loader,处理图片可使用url-loader或file-loader。

常用插件包括:

HtmlWebpackPlugin
自动生成HTML文件并注入打包后的资源
CleanWebpackPlugin
构建前清理输出目录
HotModuleReplacementPlugin
实现热模块替换(HMR),提升开发效率

Webpack开发服务器(webpack-dev-server)提供实时重新加载功能,配置中可设置端口、代理(解决跨域问题)等参数。对于React+Redux项目,手动搭建脚手架需依次配置Babel(支持JSX和ES6+)、Webpack(模块打包)、Eslint(代码规范检查)等工具链。

典型手动构建步骤包括:

  1. 初始化npm项目:npm init -y
  2. 安装核心依赖:React、ReactDOM
  3. 安装Babel相关包:@babel/core、babel-loader、@babel/preset-env、@babel/preset-react
  4. 安装Webpack相关包:webpack、webpack-cli、webpack-dev-server
  5. 配置webpack.config.js和.babelrc文件
  6. 编写入口文件(通常为src/index.js)

通过手动搭建可更深入理解构建流程,便于针对项目需求进行个性化优化(如按需加载、代码分割)。

南京柯普瑞IT学校

南京柯普瑞IT学校
认证 7 年

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 15:02:42 HTTP/1.1 GET : http://www.aabqy.com/s/1037/c/43788.html
  2. 运行时间 : 0.079102s [ 吞吐率:12.64req/s ] 内存消耗:405.48kb 文件加载:136
  3. 缓存信息 : 0 reads,0 writes
  1. /data/web/baijiao_branch_collect/public/index.php ( 0.79 KB )
  2. /data/web/baijiao_branch_collect/vendor/autoload.php ( 0.75 KB )
  3. /data/web/baijiao_branch_collect/vendor/composer/autoload_real.php ( 1.63 KB )
  4. /data/web/baijiao_branch_collect/vendor/composer/platform_check.php ( 0.90 KB )
  5. /data/web/baijiao_branch_collect/vendor/composer/ClassLoader.php ( 15.99 KB )
  6. /data/web/baijiao_branch_collect/vendor/composer/autoload_static.php ( 4.26 KB )
  7. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /data/web/baijiao_branch_collect/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /data/web/baijiao_branch_collect/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  18. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  19. /data/web/baijiao_branch_collect/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  20. /data/web/baijiao_branch_collect/app/provider.php ( 0.19 KB )
  21. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  22. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  23. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  24. /data/web/baijiao_branch_collect/app/common.php ( 10.83 KB )
  25. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  26. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  27. /data/web/baijiao_branch_collect/config/app.php ( 1.29 KB )
  28. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  29. /data/web/baijiao_branch_collect/config/cache.php ( 1.22 KB )
  30. /data/web/baijiao_branch_collect/config/config.php ( 0.26 KB )
  31. /data/web/baijiao_branch_collect/config/console.php ( 0.29 KB )
  32. /data/web/baijiao_branch_collect/config/cookie.php ( 0.56 KB )
  33. /data/web/baijiao_branch_collect/config/database.php ( 2.29 KB )
  34. /data/web/baijiao_branch_collect/config/filesystem.php ( 0.63 KB )
  35. /data/web/baijiao_branch_collect/config/lang.php ( 0.81 KB )
  36. /data/web/baijiao_branch_collect/config/log.php ( 1.37 KB )
  37. /data/web/baijiao_branch_collect/config/middleware.php ( 0.19 KB )
  38. /data/web/baijiao_branch_collect/config/route.php ( 1.54 KB )
  39. /data/web/baijiao_branch_collect/config/session.php ( 0.57 KB )
  40. /data/web/baijiao_branch_collect/config/trace.php ( 0.34 KB )
  41. /data/web/baijiao_branch_collect/config/view.php ( 0.81 KB )
  42. /data/web/baijiao_branch_collect/app/event.php ( 0.25 KB )
  43. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  44. /data/web/baijiao_branch_collect/app/service.php ( 0.13 KB )
  45. /data/web/baijiao_branch_collect/app/AppService.php ( 0.26 KB )
  46. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  47. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  48. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  49. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  50. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  51. /data/web/baijiao_branch_collect/vendor/services.php ( 0.14 KB )
  52. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  53. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  54. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  55. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  56. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  57. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  58. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  59. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  60. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  61. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  62. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.20 KB )
  63. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.75 KB )
  64. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  65. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  66. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.30 KB )
  67. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  68. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  69. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  70. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  71. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  72. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  73. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  74. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  75. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  76. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  77. /data/web/baijiao_branch_collect/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  78. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Arr.php ( 17.45 KB )
  79. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/driver/Redis.php ( 6.94 KB )
  80. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  81. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  82. /data/web/baijiao_branch_collect/app/Request.php ( 0.09 KB )
  83. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  84. /data/web/baijiao_branch_collect/app/middleware.php ( 0.26 KB )
  85. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  86. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  87. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  88. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  89. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  90. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  91. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  92. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  93. /data/web/baijiao_branch_collect/route/app.php ( 3.05 KB )
  94. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  95. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  96. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  97. /data/web/baijiao_branch_collect/app/controller/Index.php ( 33.26 KB )
  98. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Request.php ( 9.20 KB )
  99. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Url.php ( 14.07 KB )
  100. /data/web/baijiao_branch_collect/app/model/IndexModel.php ( 19.95 KB )
  101. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Config.php ( 1.37 KB )
  102. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Cache.php ( 2.06 KB )
  103. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  104. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.73 KB )
  105. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/PDOConnection.php ( 53.74 KB )
  106. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  107. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  108. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  109. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Builder.php ( 24.07 KB )
  110. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  111. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Query.php ( 15.97 KB )
  112. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  113. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  114. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  115. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  116. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  117. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  118. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  119. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  120. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  121. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  122. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  123. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  124. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  125. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  126. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  127. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  128. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  129. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  130. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/view/driver/Php.php ( 6.44 KB )
  132. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  133. /data/web/baijiao_branch_collect/view/index/pc/school_course_details.php ( 6.12 KB )
  134. /data/web/baijiao_branch_collect/view/index/pc/school_top.php ( 5.76 KB )
  135. /data/web/baijiao_branch_collect/view/index/pc/school_bottom.php ( 1.16 KB )
  136. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000235s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.001011s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '1037' AND `site_id` = 23 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000306s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000612s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 1037 [ RunTime:0.000255s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000644s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 1037 [ RunTime:0.000234s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000759s ]
  9. SELECT `a`.*,`content` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school_course_content` `b` ON `b`.`content_id`=`a`.`content_id` WHERE `school_id` = 1037 AND `a`.`content_id` = '43788' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000337s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '1037' and content_id < '43788' and site_id = '23' order by content_id desc limit 1) union all(select content_id,course_name from fqi_school_course where school_id = '1037' and content_id > '43788' and site_id <= '23' order by content_id asc limit 1) [ RunTime:0.001921s ]
  11. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 AND `school_class_id` = 4196 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000661s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 10 [ RunTime:0.001409s ]
  13. SELECT COUNT(*) AS think_count FROM `fqi_school_course` WHERE `school_id` = 1037 AND `course_status` = 1 [ RunTime:0.000415s ]
  14. SHOW FULL COLUMNS FROM `fqi_school_teacher` [ RunTime:0.000749s ]
  15. SELECT COUNT(*) AS think_count FROM `fqi_school_teacher` WHERE `school_id` = '1037' [ RunTime:0.000262s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000646s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '1037' [ RunTime:0.000199s ]
  18. SELECT `content_id`,`course_name`,`a`.`school_id`,`b`.`school_name` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school` `b` ON `b`.`school_id`=`a`.`school_id` WHERE `a`.`site_id` = '23' AND `b`.`school_status` = '1' AND `course_status` = 1 AND `course_id` < '43788' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.063883s ]
0.079570s