Schreiben Sie den Titel neu: Vue.js-Ereignisse basierend auf der Bildschirmbreite ausgeben
P粉463291248
P粉463291248 2024-03-28 10:37:34
0
1
499

Ich habe den folgenden Code aus der Seitenleiste erhalten. Wenn auf einen Link geklickt wird, sende ich außerdem ein Ereignis an die Stammkomponente und rufe dann eine Funktion auf, um die Seitenleiste auszublenden. Das funktioniert einwandfrei, aber jetzt möchte ich, dass das Ereignis nur ausgegeben wird, wenn die Bildschirmbreite weniger als 768 Pixel beträgt, sodass das Ereignis nur ausgegeben werden kann, wenn die Funktion aufgerufen werden soll.

<div class="side-links">
      <ul>
        <li>
          <router-link @click="$emit('navLinkClicked')" :to="{ name: 'Home' }"
            >Home</router-link
          >
        </li>
        <li>
          <router-link @click="$emit('navLinkClicked')" :to="{ name: 'Blog' }"
            >Blog</router-link
          >
        </li>

        <li>
          <router-link @click="$emit('navLinkClicked')" :to="{ name: 'About' }"
            >About</router-link
          >
        </li>
      </ul>
    </div>

P粉463291248
P粉463291248

Antworte allen(1)
P粉216203545

您可以使用window.innerWidth来检查当前视口的宽度。然而,全局范围变量在模板中不可用,因为它的范围仅限于您的组件。您可以创建一个处理程序方法:



或创建一个计算变量来定义宽度是否低于阈值:



就我个人而言,我会选择第一个选项,因此您只需检查一次。

在 Vue 2 中,还建议使用 kebab-case事件名称

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage