Image 自定义Web组件映像未显示

Image 自定义Web组件映像未显示,image,custom-element,createelement,Image,Custom Element,Createelement,我一直在学习Brad Traversy的yt Web组件教程,Brad Traversy是一位内容丰富的优秀教师,我相信你们中的许多人都已经知道:) 我已经达到了17分钟,尽管我遇到的问题是图像没有像教程中那样显示 正在将它们添加到文档流中。。。我可以这么说,因为布局会重新调整以适应图像的空间。。。只是图像没有显示 只是为了比较,我直接在html中添加了一个类似性质的图像,效果很好 不管怎样,这是我的代码 index.html: <!DOCTYPE html> <html la

我一直在学习Brad Traversy的yt Web组件教程,Brad Traversy是一位内容丰富的优秀教师,我相信你们中的许多人都已经知道:)

我已经达到了17分钟,尽管我遇到的问题是图像没有像教程中那样显示

正在将它们添加到文档流中。。。我可以这么说,因为布局会重新调整以适应图像的空间。。。只是图像没有显示

只是为了比较,我直接在html中添加了一个类似性质的图像,效果很好

不管怎样,这是我的代码

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Web Components Example</title>
  <style>
    h3 {
      color: purple;
    }
  </style>
</head>
<body>
  <h3>Hello World... where's the images?!?!?</h3>
  
  <!-- <user-card name="you oddo" avatar="https://randomuser.me/api/portraits/men/1.jpg"></user-card> -->

  <user-card name="huik popp" avatar="38.jpg"></user-card>

  <user-card name="som otha"></user-card>

  <img src="95.jpg">

  <style>h3 {color: green}</style>

  <script src="userCard.js"></script>
</body>
</html>

Web组件示例
h3{
颜色:紫色;
}
你好,世界。。。图像在哪里?!?!?
h3{颜色:绿色}
还有Javascript。。。 UserCard.js:

const template = document.createElement('template');
template.innerHTML = `
  <style>
    h3 {
      color: coral;
    }
  </style>
  <div class="user-card">
    <img />
    <div>
      <h3></h3>
    </div>  
  </div>
`;

class UserCard extends HTMLElement {
  constructor() {
    super();

    this.attachShadow({ mode: 'open'});
    this.shadowRoot.appendChild(template.content.cloneNode(true));
    this.shadowRoot.querySelector('h3').innerText = this.getAttribute('name');
    this.shadowRoot.querySelector('img').innerText = this.getAttribute('avatar');
  }
}

window.customElements.define('user-card', UserCard);
const template=document.createElement('template');
template.innerHTML=`
h3{
颜色:珊瑚;
}
`;
类UserCard扩展了HtmleElement{
构造函数(){
超级();
this.attachShadow({mode:'open'});
this.shadowRoot.appendChild(template.content.cloneNode(true));
this.shadowRoot.querySelector('h3').innerText=this.getAttribute('name');
this.shadowRoot.querySelector('img').innerText=this.getAttribute('avatar');
}
}
window.customElements.define('user-card',UserCard);
我将非常感谢您对我的帮助。到目前为止,我一直很喜欢跟随本教程,我想了解视频中的情况


非常感谢。

我在这里回答我的问题

在userCard.js中,我有:

this.shadowRoot.querySelector('img').innerText = this.getAttribute('avatar');
应该是:

this.shadowRoot.querySelector('img').src = this.getAttribute('avatar');

我在这里回答我的问题

在userCard.js中,我有:

this.shadowRoot.querySelector('img').innerText = this.getAttribute('avatar');
应该是:

this.shadowRoot.querySelector('img').src = this.getAttribute('avatar');

告诉Brad他可以将代码缩短为:

class UserCard extends HTMLElement {
  constructor() {
    super()
      .attachShadow({ mode: 'open'})
      .innerHTML = `
  <style>
    h3 {
      color: coral;
    }
  </style>
  <div class="user-card">
    <img />
    <div>
      <h3></h3>
    </div>  
  </div>
`;

...

  }
);
类用户卡扩展HtmleElement{
构造函数(){
超级()
.attachShadow({mode:'open'})
.innerHTML=`
h3{
颜色:珊瑚;
}
`;
...
}
);

告诉Brad他可以将代码缩短为:

class UserCard extends HTMLElement {
  constructor() {
    super()
      .attachShadow({ mode: 'open'})
      .innerHTML = `
  <style>
    h3 {
      color: coral;
    }
  </style>
  <div class="user-card">
    <img />
    <div>
      <h3></h3>
    </div>  
  </div>
`;

...

  }
);
类用户卡扩展HtmleElement{
构造函数(){
超级()
.attachShadow({mode:'open'})
.innerHTML=`
h3{
颜色:珊瑚;
}
`;
...
}
);

这很有趣,因为我刚刚遇到了一个类似的问题,我的图像没有加载。但是,我的图像仍然没有加载,即使我的脚本是直接从他的工作代码笔示例中复制的,我只是引用了类似复制的html页面内的脚本。不过其他部分显示得很好。这很有趣ng,因为我刚刚遇到了一个类似的问题,我的图像没有加载。但是,我的图像仍然没有加载,即使我的脚本是从他的工作代码笔示例中直接复制的,并且我只是引用了类似复制的html页面内的脚本。尽管其他部分显示良好。