Gif 打破了 Gatsby 网站的响应能力

Posted

技术标签:

【中文标题】Gif 打破了 Gatsby 网站的响应能力【英文标题】:Gif breaking the responsiveness of Gatsby site 【发布时间】:2021-05-17 17:38:16 【问题描述】:

问题总结

我的博文中有两个 .gif 图片,它们破坏了我网站的响应能力,在移动设备上打开它们时似乎没有调整大小。虽然从电脑打开时它们似乎很好。

PC 视图:

移动端视图:

如您所见,在移动视图中,两个 .gif 图像的大小仍然相同,这会破坏页面的响应能力。有什么办法可以解决这个问题吗?

我用来在 .mdx 文件中包含 .gif 的语法是-

![otter dancing with a fish](./neural_net_data_manupulation_2.gif)

我的站点的 Config.js 文件:

require(`dotenv`).config(
  path: `.env`,
)


const shouldAnalyseBundle = process.env.ANALYSE_BUNDLE

module.exports = 
  siteMetadata: 
    siteTitle: `Khalid Saifullah`,
    siteTitleAlt: `Khalid Saifullah - Blog`,
    author: `@k_saifullaah`,
    siteImage: `/my_banner.jpg`,
    siteHeadline: `Khalid Saifullah - Blog`,
    siteUrl: `https://khalidsaifullaah.github.io`,
    siteDescription: `I'm Khalid - a CS undergrad student. I take great interest in Deep Learning research, visualizations, and photography.`,
  ,
  plugins: [
    // `gatsby-remark-mathjax`,
    
      resolve: `@lekoarts/gatsby-theme-minimal-blog`,
      // See the theme's README for all available options
      options: 
        mdx: false,
        feedTitle: `Khalid Saifullah - Blog`,
        navigation: [
          
            title: `Blog`,
            slug: `/blog`,
          ,
          
            title: `About`,
            slug: `/about`,
          ,
          
            title: `Portfolio`,
            slug: `/portfolio`,
          ,
        ],
        externalLinks: [
          
            name: `Github`,
            url: `https://github.com/khalidsaifullaah`,
          ,
          
            name: `Twitter`,
            url: `https://twitter.com/k_saifullaah`,
          ,
          
            name: `Facebook`,
            url: `https://www.facebook.com/ikhalidsaifullaah/`,
          ,
        ],
      ,
    ,
    
            resolve: `gatsby-plugin-mdx`,
            options: 
        gatsbyRemarkPlugins: [
          `gatsby-remark-copy-linked-files`, 
           
            resolve: `gatsby-remark-images`, 
            options:  
              linkImagesToOriginal: false, 
            , 
          ,
        ],
                remarkPlugins: [ require('remark-math'), require('remark-html-katex') ]
            
        ,
    
    
      resolve: `gatsby-transformer-remark`,
      options: 
        plugins: [`gatsby-remark-copy-linked-files`],
      ,
    ,
    
      resolve: `gatsby-plugin-google-analytics`,
      options: 
        trackingId: process.env.GOOGLE_ANALYTICS_ID,
      ,
    ,
    `gatsby-plugin-sitemap`,
    
      resolve: `gatsby-plugin-manifest`,
      options: 
        name: `Khalid Saifullah - Blog`,
        short_name: `minimal-blog`,
        description: `I'm Khalid - a CS undergrad student at United International University. I take great interest in Deep Learning research, visualizations, and photography. Another aspect of me is that I'm a cinephile`,
        start_url: `/`,
        background_color: `#fff`,
        theme_color: `#6B46C1`,
        display: `standalone`,
        icons: [
          
            src: `/android-chrome-192x192.png`,
            sizes: `192x192`,
            type: `image/png`,
          ,
          
            src: `/android-chrome-512x512.png`,
            sizes: `512x512`,
            type: `image/png`,
          ,
        ],
      ,
    ,
    `remark-math`,
    `remark-html-katex`,
    `gatsby-plugin-offline`,
    `gatsby-plugin-netlify`,
    shouldAnalyseBundle && 
      resolve: `gatsby-plugin-webpack-bundle-analyser-v2`,
      options: 
        analyzerMode: `static`,
        reportFilename: `_bundle.html`,
        openAnalyzer: false,
      ,
    ,
  ].filter(Boolean),

您可以查看here帖子的实时版本

【问题讨论】:

【参考方案1】:

问题page 上的 HTML 显示图 6(a) 和 6(b) 的 GIF 图像没有响应。

这是图 6(a) 的 HTML:

<th class="css-hep4zx"><img  src="...gif" class="css-0"></th>

请注意,没有响应类。

这是一个响应式 PNG 图 3(a),具有非常不同的标记:

<th class="css-hep4zx"><span
    class="gatsby-resp-image-wrapper"
    style="position: relative; display: block; margin-left: auto;
      margin-right: auto; max-width: 650px;">
    <span
      class="gatsby-resp-image-background-image"
      style="padding-bottom: 100%; position: relative; bottom: 0px;
      left: 0px; background-image: url(...); background-size: cover;
      display: block;"
    ></span>
    <img
      class="gatsby-resp-image-image css-0"
      src="(...).png"
      style="width: 100%; height: 100%; margin: 0px; vertical-align: middle;
      position: absolute; top: 0px; left: 0px;"
    >
  </span>
</th>

为什么会有 PNG 和 GIF 的区别?

.png.gif 图像生成的非常不同的HTML 标记似乎是@​​987654322@ 插件的限制。来自文档:

支持的格式

此插件将支持以下格式:

• JPEG • PNG

结论:gatsby-remark-images 插件不会为 gif 生成响应式 HTML。

那么现在呢?

如果 gatsby-remark-images 插件不能制作响应式 GIF,是否有插件可以?

让我们尝试一个不同的插件,这里有一个示例 gif 来尝试:

使用 gatsby-remark-interactive-gifs 和推荐的 CSS 样式,生成如下 HTML:

/* CSS copied from `gatsby-remark-interactive-gifs` page */
.interactive-gif 

.interactive-gif .embedded 
  position: relative;
  width: 100%;
  height: auto;


.interactive-gif .gif-container 
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;


.interactive-gif .gif 
  width: 100%;
  height: 100%;
  cursor: pointer;
<div class="interactive-gif">
  <div class="embedded"
       style="padding-top: 56.28517823639775%">
    <div id="nyancat.gif"
         class="gif-container"
         style="display: block;">
      <img id="image-nyancat.gif"
           class="gif"
           data-original="https://i.stack.imgur.com/f7DcY.gif"
           src="https://i.stack.imgur.com/f7DcY.gif">
    </div>
  </div>
</div>

生成的 GIF 图像确实是响应式的,因此使用 gatsby-remark-interactive-gifs 似乎确实会产生响应式 GIF。

【讨论】:

那么,这是否意味着在 Gatsby 中无法使其具有响应性,而我不得不忍受它? @KhalidSaifullah 也许还有另一个插件可以为您生成响应式 GIF。例如,请参阅我的答案的补充内容。 谢谢,但我找到了一种更简单的方法,它现在可以响应了。我刚刚集成了 Bootstrap,它们现在看起来很好,也许我会在单独的答案中编写解决方案,但感谢您的帮助! @KhalidSaifullah 不错的选择,Bootstrap 让响应式布局变得非常简单。【参考方案2】:

出现问题是因为您的布局包含在 &lt;table&gt; 标记中,并带有继承 display: table。这是一个 CSS 问题,因此您需要更改该表的规则,强制换行这些 gif。

如果你能够改变你的 HTML 结构,我会建议一个更灵活和简单的结构,例如:

<div className="your-flex-wrapper">
  <img src="gif1"/>
  <img src="gif2"/>
</div>

包装器应该有一个:

.your-flex-wrapper
   display: flex;
   flex-flow: row wrap;

我已将这些更改实时应用到您的网站(在 thtr 标记中)并且:

但是,将display: flex 添加到表格布局中并不符合语义,因此最好相应地更改结构。

如果您将.gif 的宽度强制设置为小屏幕上视口的100%,它们将始终响应。

【讨论】:

【参考方案3】:

我能够通过一个非常简单的解决方案来解决我的问题。我刚刚将 Bootstrap 集成到了我的 Gatsby 系统中,然后使用了一些基本的引导网格类来使 .gifs 具有响应性。

我解决它的方法:

    首先,安装引导插件-

    npm install react-bootstrap bootstrap

    然后,在必要的地方导入插件(我已经将它导入到我的帖子的 .mdx 文件中,我已经在其中定义了这些 .gifs)-

    import 'bootstrap/dist/css/bootstrap.min.css'

    最后,我刚刚使用引导程序的方式来使这些 .gif 具有响应性(这就是我在 .mdx 文件中定义这些 .gif 的方式)-

<div class="container">
  <div class="row">
    <div class="col-sm-12 col-md-6 col-lg-6">
      <img src="./neural_net_data_manupulation_2.gif" style="width: 100%;"/>
      </div>
    <div class="col-sm-12 col-md-6 col-lg-6">
      <img src="./neural_net_decision_boundary.gif" style="width: 100%;"/>
      </div>
  </div>
</div>

这就是他们现在的样子:

大屏(PC)-

小屏(移动)-

【讨论】:

以上是关于Gif 打破了 Gatsby 网站的响应能力的主要内容,如果未能解决你的问题,请参考以下文章

如何在我的 Gatsby 博客网站中有效地显示 GIF 图像?

程序猿应具备打破思维定式的能力

在 Netlify 上部署 gatsby 站点时响应错误的大小图像

基于Gatsby的React静态化实践

使用 Netlify 和 Gatsby 减少初始服务器响应时间

9幅GIF让你秒懂响应式设计