Web图像技术:前端引入图片的各种方式及其优缺点

 前端开发人员在构建网站时需要做的一个决定是引入图片的方式。它可以是标签,或者是通过CSS background 属性,还可以使用 SVG。选择正确的方式是很重要的,它对性能和可访问性有很大的影响。

10年积累的成都网站建设、成都网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有桦川免费网站建设让你可以放心的选择与我们合作。

在本文中,我们会学习引入图像的各种方式,以及每种方式的优点和缺点,以及何时使用和为什么使用它们。

HTML img 元素

最简单的情况下,img元素必须包含src属性:

 
 
 
 
  1.  

设置宽度和高度属性

在页面加载时,它们会在页面图像加载时发生一些布局变化。为了避免这种情况,我们可以为它设置width和height属性:

 
 
 
 
  1.  

虽然对某些人来说,这可能看起来太过简单了,但它是有用的。我们用图例的方式来理清这个概念:

我们看到到右侧图片即使尚未加载仍保留了空间?那是因为设置了宽度和高度。

通过 CSS 隐藏图像

图像可以用 CSS 隐藏。但是,它仍将加载在页面中。因此,在执行此操作时请小心。如果一个图像应该被隐藏,那么它可能是出于装饰的目的。

 
 
 
 
  1. img { 
  2.     display: none; 

同样,上面的方法也不能阻止浏览器加载图像,即使它在视觉上是隐藏的。原因是被认为是一个被替换的元素,所以我们无法控制它所加载的内容。

可访问性问题

通过将alt属性设置为有意义的描述,用来访问 HTML 图像,这对于屏幕阅读器用户非常有帮助。

然而,如果一个alt描述是不需要的,请不要删除它,如果你这样做,图像src将被读出,这对可访问性非常不利。

不仅如此,如果图像因为某种原因没有加载,并且它有一个清晰的alt,它将作为一个回退显示。同样通过图例来演示一下。

假设我们有以下图片:

 
 
 
 
  1.  
  2.  
  3.  

当src无效,图片没有加载时。第一个没有alt属性,而第二个是空的alt属性,下面是它们的视觉效果:

没有alt的图片仍然保留了它的空间,这很混乱,而且不利于访问。而另一个alt为空的图片,会折叠起来看起来像一个小点,这里因为它有边框。

但是,当alt属性有值,它看起来是这样的:

这不是一个很好的反馈吗?此外,当图像源失败时,可以向它们添加伪元素。

响应式图像

的优点在于可以针对特定视口大小将其扩展为具有多个版本的照片。我们有两种不同的方式来生成一组响应式图像:

1.srcset属性

 
 
 
 
  1.  

这很简单。对我来说,srcset可以根据屏幕宽度显示多个图像尺寸,这并不是一种完美的解决方案。它让浏览器选择合适的图像,而我们对此无能为力。

2.picture 标签

另一种选择是使用 元素。我更喜欢这种方式,因为它更容易预测。

事例源码:https://codepen.io/shadeed/pen/d703aee137f38c138f2323a0252548ac?editors=1100

调整图像大小

对于,我们还可以使用的一组很好的特性object-fit和object-position。它们可以控制的大小和定位,就像CSS背景图像。

object-fit 值有:fill, contain, cover, none, scale-down。例如:

 
 
 
 
  1. img { 
  2.     object-fit: cover; 
  3.     object-position: 50% 50%; 

CSS背景图片

使用CSS背景显示图像时,它需要一个具有内容或特定宽度或高度的元素。通常,背景图像的主要用途应该是用于装饰目的。

何使用 CSS 背景图片

首先,我们需要一个元素

 
 
 
 
  1. // html 
  2. Some content
 
  •  
  • // css 
  • .element { 
  •     background: url('cool.jpg'); 
  • 多个背景

    使用CSS背景图片的好处是可以设置多个背景。考虑以下示例:

     
     
     
     
    1. .element { 
    2.     background: url('cool-1.jpg'), url('cool-2.jpg'); 

    隐藏图像

    我们可以在特定视口中隐藏和显示图像,如果未使用CSS设置图片,则不会下载该图片。与使用相比,这是一个额外的好处。

    在上面的示例中,我们有一个背景图像,仅在视口宽度大于700px时显示。

    可访问性问题

    如果使用不当,背景图像可能会影响可访问性。例如,将其用于文章主题,这对于文章至关重要。

    非开发人员无法下载

    普通人知道,如果要保存图像,只需单击鼠标左键,然后选择保存即可。CSS 背景图片并非如此,我们必须先检查元素,然后在DevTools中的url中打开链接,然后才能下载随CSS添加的图像。

    伪元素

    可以将伪元素与CSS背景图像一起使用,例如在图像顶部显示覆盖图。对于这是不可能的,直到我们为叠加层添加单独的元素。

    SVG Image

    SVG被认为是一种图像,它比较大的功能是在不影响质量的情况下进行缩放。此外,使用SVG,我们可以嵌入JPG、PNG或SVG图像。参见下面的 HTML:

    你是否注意到了prepareAspectRatio?它的作用是可以让图像占据SVG的整个宽度和高度,而不会被拉伸或压缩。

    当宽度较大时,它将填充其父级(SVG)宽度而不会拉伸。

    这非常类似于 CSS 中的object-fit: cover或background-size: cover。

    可访问性问题

    关于SVG 的可访问性,这使我想起了元素。例如,我们可以像下面这样添加它:</p><p>我们还可以使用 元素 </p><p><strong>非开发人员无法下载</strong></p><p>必须先检查元素并复制图像的URL,然后才能下载嵌入SVG的图像。但是,如果我们要防止用户下载特定的图像,这可能是一件好事。</p><p><strong>用例</strong></p><p><strong>Hero Section</strong></p><p>在构建hero section时,有时我们需要在标题和其他内容下方的图像。参见下图:</p><p>一些要求:</p><ul><li>背景图片能够动态替换</li><li>图片有一个覆盖层,让阅读更容易</li><li>图像有三种尺寸:小号、中号和大号。每一个都是针对一个特定的视口。</li></ul> <p>在开始解决方案之前,让我们先问问自己这种背景的性质。这是一些入门问题:</p><ol> <li>为用户保留这个图像很重要吗,还是可以跳过它?</li><li>我们是否需要在所有视口尺寸上使用它?</li><li>它是静态的还是动态变化的?</li></ol><p><strong>解决方案1</strong></p><p>通过使用多个CSS背景,我们可以将一个背景作为叠加层,将另一个背景作为实际图像。请看下面的CSS:</p><pre> <ol> <li>.hero { </li> <li>    background-image: linear-gradient(rgba(0, 0, 0, 0.4),  </li> <li>                                      rgba(0, 0, 0, 0.4)), var('landscape.jpg'); </li> <li>    background-repeat: no-repeat; </li> <li>    background-size: 100%, cover; </li> <li>} </li> </ol></pre><p>虽然此解决方案有效,但可以使用 JavaScript 动态更改背景图片。见下面:</p><pre> <ol> <li><section class="hero"  </li> <li>   style="background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('landscape.jpg');"> </li> <li>  <!-- Hero content --> </li> <li></section> </li> </ol></pre><p>这里添加了一个内联样式。虽然这是可行的,但它看起来很丑,而且不实用。</p><p>也许我们可以使用CSS变量?让我们来探索一下。</p><pre> <ol> <li><section class="hero" style="--bg-url: url('landscape.jpg')"> </li> <li>  <!-- Hero content --> </li> <li></section> </li> </ol></pre><p>现在,我们可以轻松地更新--bg-url变量来动态更改背, 这比内联的东西好一百万倍。</p><p>小结:</p><ol> <li>这种方案只有在图片不重要才适用</li><li>这种方案只适合一些静态网站,因为没有从后台拉取图片</li></ol><p>事例源码:https://codepen.io/shadeed/pen/17978a2d824fd51a3b27c2c2d099a522</p><p><strong>解决方案2</strong></p><p>该方案是可以使用一个 img 标签:</p><pre> <ol> <li><section class="hero"> </li> <li>  <h2 class="hero__title">Using Images in CSS</h2> </li> <li>  <p class="hero__desc">An article about which and when to use</p> </li> <li>  <img src="landscape.jpg" alt=""> </li> <li></section> </li> </ol></pre><p>在CSS中,我们需要将图片绝对定位在内容下方,并且还需要使用伪元素作为叠加层。</p><p>此解决方案的优点在于,可以轻松更改图片的src属性。同样,如果图像很重要,它将会更加有用。</p><p>另外,我喜欢使用HTML 的功能是能够在未加载图片的情况下添加回退。回退至少可以使内容保持可读性。</p><pre> <ol> <li>.hero img { </li> <li>    /* Other styles */ </li> <li>    background: #2962ff; </li> <li>  } </li> </ol></pre><p>在图片源路径不对时,背景颜色是一个代替方面。</p><p>事例源码:https://codepen.io/shadeed/pen/73a2ca78141fcab39d6db9d5bd982728?editors=1100</p><p><strong>网站 Logo</strong></p><p>网站 Logo是很重要的,因为它可以将网站与其他网站区分开。要嵌入徽标,我们有一些选择:</p><ul><li>img -> png,jpg, orsvg</li><li>内联SVG</li><li>背景图</li></ul> <p>接下来,我们来看看哪种方式更合适。</p><p><strong>带有很多细节的 Logo</strong></p><p>当徽标具有许多细节或形状时,将其用作嵌入式SVG可能没有好处。我建议使用,图像类型可以是png,jpg或svg。</p><p><strong>需要动画的简单 Logo</strong></p><p>我们有一个简单的logo ,其中包含形状和文字。悬停时,形状和文本需要更改颜色。怎么做?对我来说比较好的解决方案是使用嵌入式SVG。</p><p><strong>HTML</strong></p><p><strong>CSS</strong></p><pre> <ol> <li>.logo rect, </li> <li>.logo text { </li> <li>  transition: 0.3s ease-out; </li> <li>} </li> <li> </li> <li>.logo:hover rect, </li> <li>.logo:hover text { </li> <li>  fill: #4a7def; </li> <li>} </li> </ol></pre><p>事例源码:https://codepen.io/shadeed/pen/4005077cc543647148007f4834c0585c?editors=0100</p><p><strong>响应 Logo</strong></p><p>这让我想起了Smashing Magazine的logo。我喜欢它从一个小图标变成一个完整的徽标。参见下面的模型:</p><p>优秀的解决方案是使用 元素,可以在其中添 加logo 的两个版本。如下所示: </p><pre> <ol> <li><a class="logo" href="/"> </li> <li>    <picture> </li> <li>      <source media="(min-width: 1350px)" srcset="sm-logo--full.svg"> </li> <li>        <img src="sm-logo.svg" alt="Smashing Magazine"> </li> <li>        </picture> </li> <li>  </a> </li> </ol></pre><p>在CSS中,我们需要将视口的宽度更改为等于或大于1350px。</p><pre> <ol> <li>.logo { </li> <li>  display: inline-block; </li> <li>  width: 45px; </li> <li>} </li> <li> </li> <li>@media (min-width: 1350px) { </li> <li>  .logo { </li> <li>    width: 180px; </li> <li>  } </li> <li>} </li> </ol></pre><p>这是简单而直接的解决方案。</p><p>事例源码:https://codepen.io/shadeed/pen/6cf55d4e87b7c443820bd5f8694587a8?editors=1100</p><p><strong>带有渐变的Logo</strong></p><p>当 logo 具有渐变时,从Illustrator或Sketch等设计应用程序将其导出的过程可能并不优秀,有时会中断。</p><p>使用SVG,我们可以轻松地为logo添加渐变。我添加了 并将其用作文本填充。 </p><p>事例源码:https://codepen.io/shadeed/pen/9bf3bee3d08a40411effb5d65f25b5c1?editors=1100</p><p><strong>用户头像</strong></p><p>对于用户头像,它们具有很多形状,但最常见的是矩形或圆形。在此用例中,会介绍一个对你有用的重要技巧。</p><p>首先,让我们看下面的模型。请注意,我们有一个优秀的化身,并且100%清晰。</p><p>但是,当用户上传半白色头像或非常浅的头像时,这个设计就不太好了。</p><p>请注意,在上面的模型中,除非真正专注看,否则尚不清楚其中是否有一个圆圈。这是一个问题。为了解决这个问题,我们应该在头像内添加边框,以防图像太亮看不清除。</p><p>我们有几个选择</p><ul><li>img元素</li><li>img 和 div 元素</li><li>div与CSS背景</li><li>SVG image</li></ul> <p>哪一个比较好?我们来探索探索。</p><p><strong>使用 HTML `<img>`</strong></p><p>你可能首先想到的是添加一个边框,对吧?让我们来探讨一下这个问题。</p><pre> <ol> <li>.avatar { </li> <li>    border: 2px solid #f2f2f2; </li> <li>} </li> </ol></pre><p>我们的目标是使内部边框与图像融合在一起,这种不太实用。</p><p><strong>使用 `<img>` 和 `<div>` 元素</strong></p><p>现在的问题是,要添加内部边框,我们不能使用box-shadow,因为它无法在图像上使用。解决方案用</p><p> 包裹 头像中,并添加专用于内部边框的元素。 </p><p><strong>HTML</strong></p><pre> <ol> <li><strong><div class="avatar-wrapper"> </strong></li> <li><strong>     <img class="avatar" src="shadeed2.jpg" alt="A photo of Ahmad Shadeed"> </strong></li> <li><strong>     <div class="avatar-border"></div> </strong></li> <li><strong></div> </strong></li> </ol></pre><p><strong>CSS</strong> </p><pre> <ol> <li>.avatar-wrapper { </li> <li>  position: relative; </li> <li>  width: 150px; </li> <li>  height: 150px; </li> <li>} </li> <li> </li> <li>.avatar-border { </li> <li>  position: absolute; </li> <li>  left: 0; </li> <li>  top: 0; </li> <li>  width: 100%; </li> <li>  height: 100%; </li> <li>  border-radius: 50%; </li> <li>  border: 2px solid rgba(0, 0, 0, 0.1); </li> <li>} </li> </ol></pre><p>通过在<div>上使用透明度10%黑色的边框,我们可以确保边框与深色图像融合,并且只有在图像较亮的情况下才可见。参见下面的模型:</p><p>事例地址:https://codepen.io/shadeed/pen/da23d9a18dac14692a97e1bc6e86a5ff?editors=1100</p><p><strong>使用`<div>`与CSS背景</strong></p><p>如果我要使用<div>来显示头像,则可能表示该图像具有装饰性。我记得一个用例,它是分散在页面中的随机头像。</p><p><strong>HTML</strong></p><pre> <ol> <li><div class="avatar" style="--img-url: url(shadeed2.jpg)"></div> </li> </ol></pre><p><strong>CSS</strong></p><pre> <ol> <li>.avatar { </li> <li>  background: var(--img-url) center/cover; </li> <li>  width: 150px; </li> <li>  height: 150px; </li> <li>  border-radius: 50%; </li> <li>  box-shadow: inset 0 0 0 2px rgba(#000, 0.1); </li> <li>} </li> </ol></pre><p>事例地址:https://codepen.io/shadeed/pen/39eb9dac364ec15b9ab9bae7fe3a7148?editors=0100</p><p><strong>使用 SVG ``</strong></p><p>对我来说,这是最有趣的解决方案。我在检查Facebook的新设计时注意到了它。</p><p>先对其进行剖析,它包含以下内容:</p><ul><li>用于将图像剪切为圆形(circle )的蒙版(mask )</li><li>对其应用了蒙版的组</li><li>image本身带有preserveAspectRatio =“ xMidYMid”</li><li>用于内边界的圆</li></ul> <pre> <ol> <li>circle { </li> <li>  stroke-width: 2; </li> <li>  stroke: rgba(0, 0, 0, 0.1); </li> <li>  fill: none; </li> <li>} </li> </ol></pre><p>事例地址:https://codepen.io/shadeed/pen/b17d34b5c23cc90fdc4573779544c8c7?editors=0100</p> <p> 名称栏目:<a href="http://www.csdahua.cn/qtweb/news14/489614.html">Web图像技术:前端引入图片的各种方式及其优缺点</a> <br> 分享地址:<a href="http://www.csdahua.cn/qtweb/news14/489614.html">http://www.csdahua.cn/qtweb/news14/489614.html</a> </p> <p> 网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等 </p> <p class="adpic"> <a href="https://www.cdcxhl.com/service/ad.html" target="_blank" class="ad">广告</a> <a href="" target="_blank" class="adimg"><img src=""></a> </p> <p class="copy"> 声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: <a href="http://www.csdahua.cn/" target="_blank">快上网</a> </p> </div> <div class="newsmorelb"> <p>成都快上网为您推荐相关内容</p> <ul> <li> <a href="/qtweb/news13/489613.html">12123备案需要多久通过?(请问我的备案什么时候可以通过)</a> </li><li> <a href="/qtweb/news12/489612.html">Flex1.5环境配置步骤详尽解读</a> </li><li> <a href="/qtweb/news11/489611.html">阿里云怎么把域名绑定在服务器?阿里云服务器外网ip</a> </li><li> <a href="/qtweb/news10/489610.html">让Redis自动启动开启一种新方式(怎么自动启动redis库)</a> </li><li> <a href="/qtweb/news9/489609.html">什么是cdn清洗?(低价国外高防cdn购买有哪些优缺点)</a> </li><li> <a href="/qtweb/news8/489608.html">Oracle在你身边,让一切变得更简单</a> </li><li> <a href="/qtweb/news7/489607.html">discuz百度快照被劫持的解决办法</a> </li><li> <a href="/qtweb/news6/489606.html">一款让Python开发效率提升50%的工具包</a> </li><li> <a href="/qtweb/news5/489605.html">玩游戏总是丢包怎么回事?什么是服务器网络丢包</a> </li> </ul> </div> </div> <div class="col-lg-3 noneb"> <div class="bkright" style="margin-top: 0"> <p><a href="https://www.cdcxhl.com/news/shejigongsi/">网站设计公司知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news48/286698.html">procreate参考窗口在哪-procreate参考窗口位置介绍</a> </li><li> <a class="text_overflow" href="/qtweb/news14/235964.html">Linux语言设置从中文变为日文的解决方法(linux中文变成日文)</a> </li><li> <a class="text_overflow" href="/qtweb/news49/183899.html">edgeNAT上线韩国原生IP系列VPS全场8折促销(韩国原生ip代理)</a> </li><li> <a class="text_overflow" href="/qtweb/news5/413105.html">为什么网络掉线重启路由器就好了</a> </li><li> <a class="text_overflow" href="/qtweb/news33/154683.html">永兴网是什么,永兴网一个全民参与的互联网平台</a> </li><li> <a class="text_overflow" href="/qtweb/news1/424151.html">让Linux系统时间同步:学习如何设置(linux设置时间同步)</a> </li><li> <a class="text_overflow" href="/qtweb/news36/417336.html">为什么运动鞋这么火,运动鞋的发展历程</a> </li><li> <a class="text_overflow" href="/qtweb/news30/83280.html">如何查找php项目入口文件夹</a> </li><li> <a class="text_overflow" href="/qtweb/news10/280460.html">MySQL字符集怎么从旧字符集迁移到utf8mb4中</a> </li><li> <a class="text_overflow" href="/qtweb/news2/306652.html">Linux系统快捷关闭软件方法(linux关闭软件)</a> </li><li> <a class="text_overflow" href="/qtweb/news40/180590.html">在ADO调用存储过程中进行有效的使用</a> </li><li> <a class="text_overflow" href="/qtweb/news37/34537.html">租用上海服务器需要多少钱,在上海租用服务器的价格是多少?</a> </li><li> <a class="text_overflow" href="/qtweb/news37/403437.html">对象的序列化和反序列化</a> </li><li> <a class="text_overflow" href="/qtweb/news37/433437.html">Index表格怎么接收数据?(oneindex怎么用)</a> </li><li> <a class="text_overflow" href="/qtweb/news28/16078.html">C++TinyXml应用方式解读</a> </li> </ul> </div> <div class="bkright tag"> <p><a href="https://www.cdcxhl.com/hangye/" target="_blank">行业网站建设</a></p> <ul> <li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/jszz/" target="_blank">假山制作</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/suliaodai/" target="_blank">塑料袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/tadiaozulin/" target="_blank">塔吊租赁</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/qchs/" target="_blank">报废汽车回收</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/muwu/" target="_blank">木屋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bxgds/" target="_blank">不锈钢雕塑</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ddcl/" target="_blank">电动窗帘</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/fadianjihs/" target="_blank">发电机回收</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shipaifang/" target="_blank">石牌坊</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sdjbc/" target="_blank">隧道混凝土搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/caihui/" target="_blank">墙体彩绘</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/opp/" target="_blank">OPP胶袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/hldzj/" target="_blank">护栏打桩机</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/yupeng/" target="_blank">雨棚定制</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shayanfudiao/" target="_blank">砂岩浮雕</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/banjia/" target="_blank">搬家公司</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="https://www.cdxwcx.com/jifang/deyang.html" target="_blank">四川电信高防服务器托管</a>    <a href="http://www.cdxwcx.cn/tuoguan/yaan.html" target="_blank">雅安电信机房</a>    <a href="http://www.cdxwcx.cn/tuoguan/mianyang.html" target="_blank">绵阳服务器托管</a>    <a href="http://www.yaohuoya.com/" target="_blank">雕琢时光</a>    <a href="http://m.cdcxhl.cn/shop/ " target="_blank">商城网站</a>    <a href="http://www.cdkjz.cn/fangan/" target="_blank">企业网站设计</a>    <a href="http://www.cdkjz.cn/wangzhan/jituan/" target="_blank">成都集团网站建设</a>    <a href="http://www.cdxswst.com/" target="_blank">成都柴油发电机组</a>    <a href="http://seo.cdkjz.cn/tuiguang/" target="_blank">成都网站推广</a>    <a href="http://www.cdhuace.com/zhangui.html" target="_blank">成都展柜制作</a>    <a href="http://www.csruizhi.cn/" target="_blank">csruizhi.cn</a>    <a href="https://www.cdxwcx.com/city/ziyang/" target="_blank">资阳做网站</a>    <a href="http://www.qltuopan.com/" target="_blank">成都木托盘</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">腾讯云香港空间</a>    <a href="http://www.ybwzjz.com/" target="_blank">宜宾做网站</a>    <a href="http://www.lzluxian.com/" target="_blank">正泰动物</a>    <a href="http://m.cdcxhl.cn/dingzhi/ " target="_blank">定制网站制作</a>    <a href="https://www.cdcxhl.com/yingxiao.html" target="_blank">成都营销网站建设</a>    <a href="https://www.cdxwcx.com/wangzhan/gaiban.html" target="_blank">网站建设改版</a>    <a href="http://m.cdcxhl.cn/mobile/ " target="_blank">移动网站建设</a>     </div> </div> <footer> <div class="carousel-inner footjz"> <div class="container"> <i class="icon iconfont zbw"></i> 高品质定制 <i class="icon iconfont"></i> 跨终端自动兼容 <i class="icon iconfont"></i> 节约开发成本 <i class="icon iconfont"></i> 开发周期短 <i class="icon iconfont"></i> 一体化服务 <button type="button" class="btn btn-default btn-lg" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 立即开始2800定制网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 2800定制网站建设</button> </div> </div> <div class="carousel-inner bqsy"> <div class="container"> <div class="lxfs"> <h4 class="yutelnone">028-86922220 13518219792</h4> <h4 class="yutelblock"><a href="tel:02886922220">028-86922220</a> <a href="tel:13518219792">13518219792</a></h4> <a class="btn btn-default" href="tencent://message/?uin=532337155&Site=&Menu=yes" role="button">网站建设<span>QQ</span>:532337155</a> <a class="btn btn-default" href="tencent://message/?uin=631063699&Site=&Menu=yes" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=532337155&version=1&src_type=web&web_src=oicqzone.com" role="button">网站制作<span>QQ</span>:532337155</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=631063699&version=1&src_type=web&web_src=oicqzone.com" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn-default nonea" href="tencent://message/?uin=1683211881&Site=&Menu=yes" role="button">售后QQ:1683211881</a> <div class="dz">成都快上网专注: <a href="http://www.csdahua.cn/" target="_blank">网站优化</a> <a href="http://www.csdahua.cn/" target="_blank">网络推广</a> <a href="http://www.csdahua.cn/" target="_blank">网站建设</a> <address>地址:成都太升南路288号锦天国际A幢10楼</address> </div> </div> <div class="bzdh dz"><img src="https://www.cdcxhl.com/imges/bottom_logo.png" alt="创新互联"> <p><a href="https://www.cdcxhl.com/menu.html" target="_blank">成都创新互联科技有限公司</a><br> Tel:028-86922220(7x24h)</p></div> </div> </div> </footer> </body> </html> <script> $.getJSON ("../../qtwebpic.txt", function (data) { var jsonContent = { "featured":data } var random = jsonContent.featured[Math.floor(Math.random() * jsonContent.featured.length)]; $(".adpic .adimg").attr("href",random.link) $(".adpic img").attr("src",random.pic); }) </script>