- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不知道 components 文件夹中的 image.js 文件是否应该接受参数,指定诸如流体与固定、图像大小、应该渲染哪个图像等,然后根据参数渲染任何图像。
如果没有,是否标准使用 image.js 为要显示的每个图像基于 image.js 创建一个新文件?如果是这样,这样做有什么好处?
我阅读了有关 image.js 的内容,但我仍然不明白这个问题。
image.js 组件:https://github.com/gatsbyjs/gatsby-starter-default/blob/master/src/components/image.js
import React from "react"
import { StaticQuery, graphql } from "gatsby"
import Img from "gatsby-image"
/*
* This component is built using `gatsby-image` to automatically serve optimized
* images with lazy loading and reduced file sizes. The image is loaded using a
* `StaticQuery`, which allows us to load the image from directly within this
* component, rather than having to pass the image data down from pages.
*
* For more information, see the docs:
* - `gatsby-image`: https://gatsby.dev/gatsby-image
* - `StaticQuery`: https://gatsby.dev/staticquery
*/
const Image = () => (
<StaticQuery
query={graphql`
query {
placeholderImage: file(relativePath: { eq: "gatsby-astronaut.png" }) {
childImageSharp {
fluid(maxWidth: 300) {
...GatsbyImageSharpFluid
}
}
}
}
`}
render={data => <Img fluid={data.placeholderImage.childImageSharp.fluid} />}
/>
)
export default Image
最佳答案
这里发生了一些事情。
首先,这只是一个带有静态查询的组件的例子。它只是显示了一个示例 graphql 查询来拉入图像并呈现图像数据。您可能会从父组件调用它。
您可以为每个图像创建这样的组件,但您不必这样做。
使用上面的例子,你不能传入参数。我最近尝试过,但 graphql 内插字符串不允许传入参数,但对于此示例,有一个解决方法,如 link 所示由韦斯博斯发布。简而言之,解决方法是使用 graphql 查询返回每个图像,然后使用诸如 map 之类的东西来梳理出感兴趣的图像。使用此解决方法,我设法在您的帖子中创建了该示例的通用版本,其中我传入了感兴趣的图像的名称。但是,如果您的网站中有数百张图片,显然这并不理想。
您可以将参数传递到“页面组件”的 graphql 查询中。 Gatbsy 教程 ( https://www.gatsbyjs.org/tutorial/ ) 非常出色,我再怎么强调都不会过分阅读整个教程的值(value)。第 4 部分和第 5 部分讨论了 graphql 以及处理查询和图像。
处理图像时,建议的方法是使用 gatsby-image ( https://www.gatsbyjs.org/packages/gatsby-image/ ),该示例使用了该方法。
我还创建了另一个通用图像组件,它接受图像数据,而不是图像名称,作为 Prop 。在父页面组件中,我可以定义一个常量 graphql 查询,然后将其结果传递到我的图像组件中。这种方法可以扩展到作为图片库的页面组件。例如。查询可以返回文件夹中的所有图像或匹配正则表达式。可以通过传入图像数据来迭代查询请求,为每个图像创建一个图像组件。
我故意不包含代码示例,因为链接包含我上面描述的所有示例。
关于gatsby - gatsby-starter-default starter中Image组件的作用是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56636088/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!