React团队最近在忙啥?

距离 React 最近一次版本更新已经过去了 8 个多月。那最近 React 都在忙些啥呢?下面就来看看 React 团队最近正在研究的事,以及取得的进展!

站在用户的角度思考问题,与客户深入沟通,找到沙湾网站设计与沙湾网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、成都网站制作、企业官网、英文网站、手机端网站、网站推广、域名与空间、虚拟主机、企业邮箱。业务覆盖沙湾地区。

概览:

  • React Server Components
  • 资源加载
  • 文档元数据
  • 离屏渲染
  • Transition Tracing

React Server Components

React Server Components(RSC,服务端组件)是由 React 团队设计的一种新的应用架构。

React 团队正在引入一种新的组件——服务器组件,它提前运行并且被排除在 JavaScript 包之外。服务器组件可以在构建期间运行,从文件系统读取或获取静态内容。它们还可以在服务端运行,无需构建 API 即可访问数据层。可以通过 props 将数据从服务端组件传递到浏览器中的交互式客户端组件。

RSC 将以服务端为中心的多页面应用的简单“请求/响应”心智模型与以客户端为中心的单页应用的无缝交互相结合,提供了两全其美的体验。

自上次更新以来,React 团队合并了 React 服务端组件 RFC 以批准该提案。通过 [React Server Module Conventions](React Server Module Conventions) 提案解决了悬而未决的问题,并与合作伙伴达成共识以遵循“use client”的约定。这些文档还充当 RSC 兼容实现应支持的规范。

最大的变化就是引入了 async / await​ 作为从服务端组件获取数据的主要方式。 除此之外,还计划通过引入一个名为 ​​use​​​ 的新 Hook 来支持从客户端加载数据,该 Hook 用于解包 Promises。虽然不能在仅客户端应用的任意组件中支持 ​​async / await​​,但计划在构建仅客户端应用时添加对它的支持,类似于 RSC 应用的结构。

现在已经解决了数据获取的问题,并正在探索另一个方向:将数据从客户端发送到服务器,以便可以执行数据库突变和实现表单。通过让跨服务端/客户端边界传递服务端操作(Server Action)函数来实现这一点,然后客户端可以调用这些函数,从而提供无缝的 RPC。Server Actions 还在 JavaScript 加载之前提供逐步增强的表单。

React 服务端组件已经在 Next.js 应用路由中发布。这展示了一个真正将 RSC 视为原语的路由的深度集成,但这并不是构建与 RSC 兼容的路由和框架的唯一方法。RSC 规范和实现提供的特性有明显的区别。React 服务端组件是指跨兼容React框架工作的组件规范。

React 团队通常建议使用现有框架,但如果需要构建自己的自定义框架,也是可以的。构建自己的 RSC 兼容框架并不容易,因为需要深度构建工具集成。当前一代的构建工具非常适合在客户端上使用,但它们在设计时并没有为在服务端和客户端之间拆分单个模块图提供一流的支持。这就是为什么 React 团队现在直接与构建工具开发人员合作以获得内置的 RSC。

资源加载

Suspense 允许指定在组件的数据或代码仍在加载时在屏幕上显示什么内容。这使用户可以在页面加载时以及加载更多数据和代码的路由导航期间逐步看到更多内容。但是,从用户的角度来看,在考虑新内容是否准备就绪时,数据加载和渲染并不能说明全部。默认情况下,浏览器独立加载样式表、字体和图像,这可能导致 UI 跳转和连续的布局转换。

React 团队正在努力将 Suspense 与样式表、字体和图像的加载生命周期完全集成,以便 React 将它们考虑在内,以确定内容是否已准备好显示。在不改变编写 React 组件的方式的情况下,更新将以更加连贯的方式进行。作为一种优化。,还将提供一种手动方式来直接从组件中预加载字体等资源。

文档元数据

应用中的不同页面可能具有不同的元数据,例如  标签、description 和其他特定于此页面的 <meta> 标签。从维护的角度来看,将此信息放在该页面的 React 组件中会更具可扩展性。但是,此元数据的 HTML 标签需要位于文档的 <head> 中,该文档通常在应用的最根组件中。</p><p>现在有两种方法可以解决这个问题:</p><ul><li>渲染一个特殊的第三方组件,该组件将 <title>、<meta> 和其中的其他标签移动到文档的 <head> 中。这适用于主流浏览器,但有许多客户端不运行客户端 JavaScript,例如 Open Graph 解析器,因此该技术并不普遍适用。</li><li>将页面分为两部分进行服务端渲染。首先,渲染主要内容并收集所有此类标签。然后使用这些标签渲染 <head> 。最后,<head> 和主要内容被发送到浏览端。这种方法是可行的,但这样就不能使用 React 18 中的流式服务端渲染了,因为必须等待所有内容渲染完毕才能发送 <head>。</li></ul> <p>这就是为什么 React 要 在组件树中的任何位置添加内置支持来渲染 <title>、<meta>​ 和元数据 <link> 标签。它在所有环境中都以相同的方式工作,包括完全的客户端代码、SSR,以及未来的 RSC。</p><h2>React 优化编译器</h2> <p>​React 团队一直在积极迭代 React Forget 的设计,这是一个针对 React 的优化编译器。之前曾将其称为“自动记忆编译器”,这在某种意义上是正确的。但是构建编译器帮助 React 团队更深入地理解了 React 的编程模型。理解 React Forget 的更好方法是将其作为一个自动响应式编译器。</p><p>React 的核心思想是开发人员将 UI 定义为当前状态的函数。使用普通的 JavaScript 值:数字、字符串、数组、对象,并使用标准的 JavaScript 语法:if/else、for 等描述组件逻辑。心智模型是 React 将在应用状态更改时重新渲染。这种简单的心智模型和与 JavaScript 语义保持接近是 React 编程模型中的一个重要原则。</p><p>问题是 React 有时会响应过度:它会重新渲染太多。例如,在 JavaScript 中没有直接的方法来比较两个对象或数组是否相等(具有相同的键和值),因此在每次渲染时创建一个新的对象或数组可能会导致 React 执行比它严格需要的更多的工作。这意味着开发人员必须明确记忆组件,以免对更改响应过度。</p><p>React Forget 的目标是确保 React 应用在默认情况下具有适量的响应:应用仅在状态值发生有意义的变化时才重新渲染。从实现的角度来看,这意味着自动记忆,但 React 团队认为响应式框架是理解 React 和 Forget 的更好方式。React 目前会在对象标识更改时重新渲染。有了 Forget,React 会在语义值发生变化时才重新渲染——但不会产生深度比较的运行时成本。</p><p>进展而言,自上次更新以来,React 团队对编译器的设计进行了大量迭代,以与这种自动响应式方法保持一致,并纳入内部使用编译器的反馈。在去年年底开始对编译器进行一些重大重构之后,现在已经开始在 Meta 部分生产中使用编译器。一旦在生产中证明了它的价值,就计划将其开源。​</p><h2>离屏渲染</h2> <p>离屏渲染是 React 即将推出的一项功能,用于在后台渲染屏幕而无需额外的性能开销。可以将其视为 CSS 属性 ​<code>​content-visibility​</code>​ 的一个版本,它不仅适用于 DOM 元素,也适用于 React 组件。在研究过程中,发现了各种用例:</p><ul><li>路由可以在后台预渲染页面,以便当用户导航到该页面时,页面立即可用;</li><li>选项卡切换组件可以保留隐藏选项卡的状态,因此用户可以在它们之间切换而不会丢失进度。</li><li>虚拟列表组件可以在可见窗口上方和下方预渲染额外的行。</li><li>打开模态框或弹出窗口时,可以将应用的其余部分置于“后台”模式,以便除模式之外的所有内容都禁用事件和更新。</li></ul> <p>大多数 React 开发人员不会直接与 React 屏幕外的 API 交互。相反,离屏渲染将被集成到路由和 UI 库中,使用这些库的开发人员将自动受益,而无需额外的工作。</p><p>这个功能可以让我们在不改变编写组件的方式的情况下在屏幕外渲染任何 React 树。当一个组件在屏幕外渲染时,它实际上并没有挂载,直到组件可见——它的 effect 不会被触发。离屏渲染的一个关键特性就是可以在不丢失其状态的情况下切换组件的可见性。</p><p>自上次更新以来,React 团队在 Android 和 iOS 上的 React Native 应用中测试了 Meta 内部预渲染的实验版本,并取得了积极的性能结果。除此之外,还改进了离屏渲染与 Suspense 的工作方式——在离屏树内暂停不会触发 Suspense 回退。剩下的工作就涉及完成向库开发人员公开的原语。希望在今年晚些时候发布一个 RFC,以及一个用于测试和反馈的实验性 API。</p><h2>Transition Tracing</h2> <p>Transition Tracing API 可以检测 React Transitions 何时变慢并调查它们变慢的原因。在上次更新后,React 团队完成了 API 的初始设计并发布了 RFC,基本能力也已经实现,该项目目前处于搁置状态。欢迎对 RFC 进行反馈,并期待恢复其开发,为 React 提供更好的性能测量工具。这对于构建在基于 React Transitions 的路由特别有用,比如 Next.js 应用路由。</p><blockquote style="margin-top: 5px;margin-bottom: 5px;padding-left: 1em;margin-left: 0px"> <p><strong>参考</strong>:https://react.dev/blog/2023/03/22/react-labs-what-we-have-been-working-on-march-2023</p></blockquote> <br> 网站名称:React团队最近在忙啥? <br> 文章路径:<a href="http://www.zjjierui.cn/article/cohiojh.html">http://www.zjjierui.cn/article/cohiojh.html</a> </div> </div> <div class="other"> <h3>其他资讯</h3> <ul> <li> <a href="/article/dpdhgic.html">怎么设置代理?(怎么设置代理服务器地址)</a> </li><li> <a href="/article/dpdhgoh.html">3ds30材质该搭配什么光影?windows配置ruby</a> </li><li> <a href="/article/dpdhihp.html">MySQL死锁问题实例分析及解决方法</a> </li><li> <a href="/article/dpdhgis.html">eune是什么服务器?欧洲研发服务器</a> </li><li> <a href="/article/dpdhgdg.html">Flex与Java中的Object交互</a> </li> </ul> </div> </div> <div class="f_service_con"> <div class="h_fumin"> <div class="h_fumin_lei"> <div class="h_fumin_lei_tu"><img src="/Public/Home/images/f_service01.png"></div> <p>售后响应及时</p><span>7×24小时客服热线</span> </div> <div class="h_fumin_lei"> <div class="h_fumin_lei_tu"><img src="/Public/Home/images/f_service02.png"></div> <p>数据备份</p><span>更安全、更高效、更稳定</span> </div> <div class="h_fumin_lei"> <div class="h_fumin_lei_tu"><img src="/Public/Home/images/f_service03.png"></div> <p>价格公道精准</p><span>项目经理精准报价不弄虚作假</span> </div> <div class="h_fumin_lei"> <div class="h_fumin_lei_tu"><img src="/Public/Home/images/f_service04.png"></div> <p>合作无风险</p><span>重合同讲信誉,无效全额退款</span> </div> </div> </div> <div class="footerbar"> <div class="footer-t"> <div class="f-box"> <div class="f-1"> <div class="f-t"> <h2>联系我们</h2> <span>TEL</span> </div> <div class="f-b"> <h1><a href="tel:13518219792" rel="nofollow">135-1821-9792</a></h1> <h1><a href="tel:028-86922220" rel="nofollow">028-86922220</a></h1> <p>地址:成都市太升南路288号锦天国际</p> </div> </div> <div class="f-2"> <div class="f-t"> <h2>快捷导航</h2> <span>Shortcut</span> </div> <div class="f-b"> <ul > </ul> <ul > <li><a href="/jianshe" title="广元网站建设">广元网站建设</a></li> <li><a href="/jianshe#ym_websiteBox2" title="品牌网站建设">品牌网站建设</a></li> <li><a href="/jianshe#ym_websiteBox1" title="企业网站建设">企业网站建设</a></li> <li><a href="/jianshe#ym_websiteBox4" title="集团网站建设">集团网站建设</a></li> <li><a href="/jianshe#ym_websiteBox4_2" title="外贸网站建设">外贸网站建设</a></li> <li><a href="/jianshe#ym_websiteBox4_5" title="企业宣传视频">企业宣传视频</a></li> </ul> <ul > <li><a href="/weixin" title="微信开发">微信开发</a></li> <li><a href="/weixin#item1" title="公众号开发">公众号开发</a></li> <li><a href="/weixin#item2" title="微商城建设">微商城建设</a></li> <li><a href="/weixin#item3" title="微官网建设">微官网建设</a></li> <li><a href="/weixin#item4" title="小程序开发">小程序开发</a></li> </ul> <ul> <li><a href="/case/" title="网站作品案例">网站作品案例</a></li> <li><a href="/case/" title="品牌网站案例">品牌网站案例</a></li> <li><a href="/case/" title="集团网站案例">集团网站案例</a></li> <li><a href="/case/" title="企业网站案例">企业网站案例</a></li> <li><a href="/case/" title="外贸网站案例">外贸网站案例</a></li> <li><a href="/case/" title="营销网站案例">营销网站案例</a></li> </ul> <ul style="margin:0;"> <li><a href="/about/">广元建站</a></li> <li><a href="/about/">公司简介</a></li> <li><a href="/about#ab_item3">企业文化</a></li> <li><a href="/contact">联系我们</a></li> <li><a href="/Pay.html">付款方式</a></li> <li><a href="/jianshe#ym_websiteBox8">售后服务</a></li> </ul> <div style="clear:both;"></div> </div> </div> <div class="f-3"> <div class="f-t"> <h2>二维码</h2> <span>QR CODE</span> </div> <div class="f-b"> <ul> <li><img src="/Public/Home/images/fewm.png"> <p>微信公众号</p> </li> <li style="margin: 0"><img src="/Public/Home/images/fewm2.png"> <p>手机端网站</p> </li> <div style="clear:both;"></div> </ul> </div> </div> <div style="clear:both;"></div> </div> </div> <div class="footer-about"> <div class="w1200">广元优众联杰建站公司是一家专注从事于高品质视觉体验及互联网设计开发,<a href="/" target="_blank">广元网站建设</a>,<a href="/jianshe" target="_blank">广元网站设计</a>,<a href="/jianshe" target="_blank">广元网页设计</a>,<a href="/jianshe" target="_blank">广元网站制作</a>,<a href="/jianshe#ym_websiteBox2" target="_blank">品牌网站建设</a>,<a href="/jianshe#ym_websiteBox3" target="_blank">营销网站建设</a>,<a href="/jianshe#ym_websiteBox4" target="_blank">集团网站建设</a>,<a href="/jianshe#ym_websiteBox1" target="_blank">企业网站建设</a>,<a href="/jianshe#ym_websiteBox4_2" target="_blank">外贸网站建设</a>,<a href="/jianshe#ym_websiteBox4_3" target="_blank">响应式网站建设</a>,<a href="/weixin#item4" target="_blank">小程序开发</a>,<a href="/weixin" target="_blank">微信开发</a>,<a href="/jianshe#ym_websiteBox4_4" target="_blank">企业形象设计</a>,<a href="/jianshe#ym_websiteBox4_5" target="_blank">企业宣传视频</a>等服务,优众联杰建站位于广元市龙岗区大运软件小镇,优众联杰建站拥有经验丰富的高级网站建设工程师和一流的网页高端设计人员,具备各种规模与类型网站建设的雄厚实力,在网站建设领域树立了自己独特的设计风格。 </div> <div class="friend-links"> <h6 class="clearfix"> <span class="tilte">友情链接</span> <a class="exchagne" href="http://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes">交换友情链接</a> </h6> <div class="link-list clearfix"> <div class="link-slider"> <a href="https://www.xwcx.net/tuoguan.html" title="四川电信机房托管" target="_blank">四川电信机房托管</a>   <a href="http://m.cdcxhl.cn/applets/ " title="成都小程序开发" target="_blank">成都小程序开发</a>   <a href="http://www.qyyxtuwen.com/" title="qyyxtuwen.com" target="_blank">qyyxtuwen.com</a>   <a href="http://www.waiwusige.com/" title="大悟县体育器材" target="_blank">大悟县体育器材</a>   <a href="http://www.xjhxzp.com/" title="商用广告纸杯" target="_blank">商用广告纸杯</a>   <a href="http://www.dmvi.cn/ser/huace/" title="企业画册设计制作" target="_blank">企业画册设计制作</a>   <a href="http://www.hheauq.com/" title="成都喷绘广告" target="_blank">成都喷绘广告</a>   <a href="http://www.cdxwcx.cn/tuoguan/leshan.html" title="乐山主机托管" target="_blank">乐山主机托管</a>   <a href="http://www.fzdkfx.com/" title="广告招牌标识设计" target="_blank">广告招牌标识设计</a>   <a href="http://www.cdqiyeyouxiang.com/" title="成都企业邮箱公司" target="_blank">成都企业邮箱公司</a>    </div> </div> </div> </div> <div class="footer-b"> <div class="f-box"> <ul> <li><a href="/jianshe#ym_websiteBox6" target="_blank">服务流程</a></li> <li><a href="/jianshe#ym_websiteBox8" target="_blank">售后服务</a></li> <li><a href="/about/" target="_blank">联系我们</a></li> <li><a href="https://www.cdxwcx.com/pay/" target="_blank">付款方式</a></li> <li><a href="https://www.cdcxhl.com/menu.html" target="_blank">网站地图</a></li> <li><a href="#" target="_blank">sitemap</a></li> <li> <p> <script data-cfasync="false" src="/Public/Home/js/email-decode.min.js"></script> </p> </li> <div style="clear:both;"></div> </ul> <p class="copy">Copyright © 2025 成都优众联杰科技有限公司 广元建站公司 All Rights Reserved   <a href="https://beian.miit.gov.cn/" target="_blank" rel="nofollow">蜀ICP备2024116266号-5</a> <a style="display:none" target="_blank" href="###"><img style="vertical-align:middle" border="0" src="" width="65" height="25" /></a> </p> <div style="clear:both;"></div> </div> </div> <div class="sj_footer"> <div class="f-box"> <ul> <li><a href="/jianshe" target="_blank">网站建设</a></li> <li><a href="/jianshe#ym_websiteBox6" target="_blank">服务流程</a></li> <li><a href="/jianshe#ym_websiteBox8" target="_blank">售后服务</a></li> <li><a href="https://www.cdxwcx.com/pay/" target="_blank">付款方式</a></li> <li><a href="/about/" target="_blank">关于我们</a></li> <li><a href="https://www.cdcxhl.com/menu.html" target="_blank">网站地图</a></li> <div style="clear:both;"></div> </ul> <p class="copy">Copyright © 2025 成都优众联杰科技有限公司 广元建站公司 </p> <p class="copy"> <a href="https://beian.miit.gov.cn/" target="_blank" rel="nofollow">蜀ICP备2024116266号-5</a>  <a href="###" target="_blank"><img src="/Public/Home/images/govicon.gif" width="20" height="28" border="0" style="border-width:0px;border:hidden; border:none;"></a></p> <div style="clear:both;"></div> </div> </div> </div> <script type='text/javascript' src='/Public/Home/js/qqkefu.js'></script> <div class="qqkefu"> <ul> <li class="qq_czaa" id="130"><b class="a"></b>135-1821-9792</li> <li class="qq_czaa" id="130"><a href="tencent://message/?uin=1683211881"><b class="b"></b>业务咨询QQ</a></li> <li class="qq_czaa" id="130"><a href="javascript:showDiv()"><b class="f"></b>提交合作意向表</a></li> <li class="qq_czb"> <b class="c"></b> <div class="erweima"> <p><img src="/Public/Home/images/right_erweima.png"></p> </div> </li> <li class="top"><span></span></li> </ul> </div> <div id="popDiv" class="mydiv" style="display:none;"> <a class="mydiv_clk" href="javascript:closeDiv()">X</a> <div class="mydiv_list"> <div class="c_f_title"><span class="c_f_t">合作意向表</span></div> <div class="c_f_con"> <form id="form1" name="form1" class="mess_form" method="post" action="/post_order"> <input name='enews' type='hidden' value='AddFeedback'> <input name="bid" value="1" type="hidden"> <input type="hidden" name="ecmsfrom" value="9"> <input type="hidden" name='title' value="客户提交需求"> <li class="c_n"><span>公司名称</span> <dl><input name='gsname' id='gsname' type="text"></dl> </li> <li class="c_n"><span>邮箱</span> <dl><input name='gemail' id='gemail' type="text"></dl> </li> <li class="c_n xmm"> <div class="xmm_01"><span>姓名</span> <dl class="c_n_i"><input name='name' id='name' type="text"></dl> </div> <div class="xmm_01"><span style="text-align:center">电话</span> <dl class="c_n_i"><input name="tel" type="text"></dl> </div> </li> <li class="c_tser">您需要的服务</li> <li class="clearfix"> <dd><label><input type="radio" name='hobby' id='hobby' value="高端网站建设"><span>高端网站建设</span></label></dd> <dd><label><input type="radio" name='hobby' id='hobby' value="我需要做微信营销"><span>我需要做微信营销</span></label></dd> <dd><label><input type="radio" name='hobby' id='hobby' value="要找长期合作,需要年度服务"><span>要找长期合作,需要年度服务</span></label></dd> <dd><label><input type="radio" name='hobby' id='hobby' value="我需要做购物商城"><span>我需要做购物商城</span></label></dd> <dd><label><input type="radio" name='hobby' id='hobby' value="我需要网站改版"><span>我需要网站改版</span></label></dd> <dd><label><input type="radio" name='hobby' id='hobby' value="其他"><span>其他</span></label></dd> </li> <li class="c_tser">您关注的地方</li> <li class="clearfix"> <dd><label><input type="radio" name='hobby2' id='hobby2' value="对功能要求比较高"><span>对功能要求比较高</span></label></dd> <dd><label><input type="radio" name='hobby2' id='hobby2' value="对设计创意要求比较高"><span>对设计创意要求比较高</span></label></dd> <dd><label><input type="radio" name='hobby2' id='hobby2' value="需要可以购物支付"><span>需要可以购物支付</span></label></dd> <dd><label><input type="radio" name='hobby2' id='hobby2' value="搜索引擎排名"><span>搜索引擎排名</span></label></dd> </li> <li class="c_tser">预算</li> <li class="clearfix clearfix2"> <dd><label><input type="radio" name='hobby3' id='hobby3' value="一万以内"><span>一万以内</span></label> </dd> <dd><label><input type="radio" name='hobby3' id='hobby3' value="1-3万"><span>1-3万</span></label> </dd> <dd><label><input type="radio" name='hobby3' id='hobby3' value="3-5万"><span>3-5万</span></label> </dd> <dd><label><input type="radio" name='hobby3' id='hobby3' value="5万以上"><span>5万以上</span></label> </dd> <dd><label><input type="radio" name='hobby3' id='hobby3' value="需招投标"><span>需招投标</span></label> </dd> </li> <li class="c_n" style="border-top:1px solid #eee; padding-top:10px"><span>验证码</span> <dl class="c_n_i yzmm"><input type="text" name='code' id='code' value=""></dl><span style="text-align:center"><img src="/Public/Home/images/1661eb19783442c38063791555cd0d80.gif" onclick="this.src=this.src + '?'" width="100" height="40"></span> </li> <li class="clearfix"> <dd class="submit"><input name='submit' type="submit" value="提交需求"></dd> </li> </form> </div> </div> </div> <div id="bg" class="bg" style="display:none;"></div> <div id='popIframe' class='popIframe' frameborder='0'></div> <script> //提交需求选项 $(document).ready(function (e) { $(".mess_form").submit(function () { if ($("#gsname").val() == "") { alert("请填写您的公司名称!"); $("#gsname").focus(); return false; } if ($("#gemail").val() == "") { alert("请填写您的邮箱"); $("#gemail").focus(); return false; } if ($("#name").val() == "") { alert("请填写您的姓名!"); $("#name").focus(); return false; } if ($("#tel").val() == "") { alert("请填写您的电话!"); $("#tel").focus(); return false; } if ($("#hobby").val() == "") { alert("请选择您需要的服务!"); $("#hobby").focus(); return false; } if ($("#hobby2").val() == "") { alert("请选择您关注的地方!"); $("#hobby2").focus(); return false; } if ($("#hobby3").val() == "") { alert("请选择您的预算!"); $("#hobby3").focus(); return false; } if ($("#code").val() == "") { alert("请填写正确的验证码!"); $("#code").focus(); return false; } }); }); </script> <script language="javascript" type="text/javascript"> //提交需求窗口 function showDiv() { document.getElementById('popDiv').style.display = 'block'; document.getElementById('popIframe').style.display = 'block'; document.getElementById('bg').style.display = 'block'; } function closeDiv() { document.getElementById('popDiv').style.display = 'none'; document.getElementById('bg').style.display = 'none'; document.getElementById('popIframe').style.display = 'none'; } </script> <script type="text/javascript" src="/Public/Home/js/scrolltopcontrol.js"></script> <script type="text/javascript" src="/Public/Home/js/su_new.js"></script> </body> </html> <script> $(".con img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>