Next.js 背景图像 css 属性 无法加载图像

Next.js background-image css property cant load the image

问题只是我正在尝试访问静态图像以在 React 中的内联背景图像 属性 中使用。

我正在使用 reactjs,next.js 然后我遇到了使用 next.js 添加图像的问题,但通过使用名为 Next.js + Images,[=16 的图像加载器解决了这个问题=]

现在我可以使用普通 html img 标签正常添加图像

示例:<img src={ img } /> 这行得通。

但是当我尝试添加 css 背景图片时,如下所示:

const team = (props) => {
const img = require("../../assets/images/security-team.jpg");
const styling = {
    backgroundImage: `url('${img}')`,
    width:"100%",
    height:"100%"
}
console.log(img);
return (
    <dev className="team" style={styling}>

    </dev>
);

}

这是 console.log 结果:

/_next/static/images/security-team-449919af8999ae47eaf307dca4dda8e1.jpg

图像没有出现,然后没有发生错误,我尝试在浏览器网站中输入-url + console.log 结果图像出现了!

当我使用 JSX 样式然后添加绝对位置时 属性 它工作得很好。

像这样:

 <style JSX>{`
    .team {
        width:100%;
        height:100%;
        position:absolute;
        background: url('`+img+`') no-repeat;
    }
`}</style>

如果您将图像放在“/static/images/”文件夹中,您也可以尝试使用“/static/images/security-team.jpg”而不导入。 例如:

const styling = {
  backgroundImage: "url('/static/images/security-team.jpg')",
  width:"100%",
  height:"100%"
}
return (
  <div className="team" style={styling}></div>
);

next-images 包适合我。

第一个:

yarn add next-images

然后,在 next.config.js 文件中:

const withImages = require('next-images')
module.exports = withImages()

那么你可以这样做:

<div
  style={{
    backgroundImage: "url(" + `${require("./path-to-the-image")}` + ")",
    width: "100%",
    height:[HEIGHT OF THE IMAGE],
    backgroundRepeat: "no-repeat",
    backgroundSize: "cover"
  }}
>XXX</div>

有关下一张图片的更多信息:https://github.com/twopluszero/next-images

你可以把图片放在public文件夹里,然后这样访问:

const team = (props) => {
const styling = {
    backgroundImage: `url('./security-team.jpg')`,
    width:"100%",
    height:"100%"
}
return (
    <dev className="team" style={styling}>

    </dev>
);

css 文件 在 styles/home.scss

图像文件 public/bg-img.png

.content_bg {
    margin: 50px 0;
    background-image: url('../public/bg-img.png');
    height: 500px;
    background-size: cover;
    background-repeat: no-repeat;
}

你所要做的就是改变url

来自 background-image: url('/public/images/my-img.jpg');

background-image: url('/static/images/my-img.jpg');

/static 目录已弃用。任何尝试使用它的人都可能会在他们的控制台中收到错误消息,但这里 link 包含 NextJS 对他们选择弃用静态目录的原因的解释。

Because public also covers the static directory use case we have decided to deprecate the static directory in favor of creating a public/static folder with the same functionality.

我设法通过使用图像对象的 src 属性 解决了这个问题,所以:

{ img.src }

他们的文档显示了通过以下方法实现的背景图片:

import Image from 'next/image'
<Image />

这是一个现场演示 - https://image-component.nextjs.gallery/background

<div className="VistaCodeLab" style={{backgroundImage: ` url('')`}}></div>

像这样使用 base64 图片

在线图片转base64工具 https://www.base64-image.de/

图片必须在 public(顺风示例)

<div className="my-5 lg:my-6">
 <img src="/logotipo/logo.png" alt="easybanklogo" />
</div>

使用 next@11.0 我将我的图像放在 public 文件夹中,然后在样式文件中我使用了以下内容并且它起作用了。

background-image: url('/image.svg');

首先导入图片文件

import bg from '../../assets/images/security-team.jpg'

然后应用内联样式

style={{
      backgroundImage: `url(${bg.src})`,
      width: '100%',
      height: '100%',
    }}
 <div
  class="horizontal-layout horizontal-menu navbar-static dark-layout 1-column footer-static bg-full-screen-image  blank-page blank-page"
  data-open="hover"
  data-menu="horizontal-menu"
  data-col="1-column"
  data-layout="dark-layout"
  style={{ backgroundImage: "url(/assets/images/pages/auth-bg.jpg)" }}
>
Example using Nextjs, node modules and scss.

    import styles from "../styles/Home.modules.scss"
    import Image from "next/image"
    export default function Home() {
      <div className={styles.background_image}> 
        <Image
          width={2746}  //use the width of the image being used
          height={4681} //use the height of the image being used
          layout="fill"
          alt="water_portrait"
          src="/home/water_portrait.jpg" //image saved in public/home
        />
      </div>
   }

  //styles/Home.module.scss
  .background_image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 1;
  }
  .somethingElse{
      positsion: relative;
      z-index:10;
  }

这里的所有解决方案都不允许 NextJs 自定义 <Image> 组件的主要优势,该组件默认提供优化的响应式图像并具有巨大的优势。如果可以,我会使用 z-index 来“伪造”一个 css 背景图像。

但是,此方法确实存在限制,即没有像 CSS 背景那样的可重复选项。

请注意,此示例使用 Tailwind CSS。

<div className="h-screen">
    <div className="absolute -z-10">
        <Image
            src="/some.jpeg"
            layout="fill"
            objectFit="cover"
            quality={100}
        />
    </div>
    <div> Some overlay things go in here </div>
</div>

使用动态图片

首先像这样声明样式

 let style = {
        backgroundImage: "url(" + props.image + ")",
    }

然后

<div style={style}>
    <div className="content">content here</div>
</div>

正如 nextjs 文档所说 (https://nextjs.org/docs/basic-features/static-file-serving):

Next.js can serve static files, like images, under a folder called public in the root directory.

Files inside public can then be referenced by your code starting from the base URL (/).

因此,从 public 文件夹中引用我们的图片的正确方法是:

CSS 示例:

background-image: url('/your-image.jpg');

JSX 示例:

import Image from 'next/image'
<Image src="/your-image.jpg" alt="Image description" width="64" height="64" />

我正在使用 Next.js v12.0.10,当我尝试以下操作时无法加载 css 背景图片:

<div style={{ backgroundImage: "url('/public/a.jpg')"}}>
</div>

但是当我在图像 url 中省略 /public 时,一切正常:

<div style={{ backgroundImage: "url: '/a.jpg')"}}>
</div>

就像伊万上面说的:

Files inside public can then be referenced by your code starting from the base URL (/).