You’re browsing the documentation for v2.x and earlier. For v3.x, click here.
This page assumes you’ve already read the Components Basics. Read that first if you are new to components.
In 2.6.0, we introduced a new unified syntax (the v-slot
directive) for named and scoped slots. It replaces the slot
and slot-scope
attributes, which are now deprecated, but have not been removed and are still documented here. The rationale for introducing the new syntax is described in this RFC.
- @Ceijay I see 2 m2 slots so I should be ok? There is only one M.2 NVMe connector on the mobo. If you want a second M.2 NVME you would need a PCIe adapter, something like this. Hopefully you do not have the liquid cooled graphics card. You have already added heat 🔥 to your system with the HDD spinner. Be cautious about adding additional heat.
- Segotep CVN B460I GAMING FROZEN V20 LGA1200/ Intel B460/ DDR4/ SATA3.0/ USB3.2 Gen1 Ports/ M.2/ DP HDMI/ WiFi/BT Module Slot/ WiFi6 Wireless LAN ITX Gaming Motherboard.
- 777 slots: the most basic type of slots with three reels. Vegas Slots: a real life version of the aforementioned Vegas slots online, a type of machine that has been popularized in Vegas back in the 20th century. Old slots: classic slots that have limited functionality but are still popular. The examples are Lord of the Ocean slot and the Royal.
- Video slots – Video slots are the most common online slots for free. They are known for having several in-game features, bonus rounds, special symbols, and mind-blowing gameplay. They also have a range of themes with unique storylines, soundtracks, and HD graphics.
Pwr Extra Long 12 Ft 2-Prong AC Wall 2 Slot Power Cord L-Type for Samsung LED LCD TV Smart Monitor, Xbox One-S X, PS5 PS4 Slim Console Cable (Figure 8) - 3903-0-000599 4.8 out of 5 stars 1,532.
Slot Content
Vue implements a content distribution API inspired by the Web Components spec draft, using the <slot>
element to serve as distribution outlets for content.
This allows you to compose components like this:
Then in the template for <navigation-link>
, you might have:
When the component renders, <slot></slot>
will be replaced by “Your Profile”. Slots can contain any template code, including HTML:
Or even other components:
If <navigation-link>
‘s template did not contain a <slot>
element, any content provided between its opening and closing tag would be discarded.
Compilation Scope
When you want to use data inside a slot, such as in:
That slot has access to the same instance properties (i.e. the same “scope”) as the rest of the template. The slot does not have access to <navigation-link>
‘s scope. For example, trying to access url
would not work:
As a rule, remember that:
Everything in the parent template is compiled in parent scope; everything in the child template is compiled in the child scope.
Fallback Content
There are cases when it’s useful to specify fallback (i.e. default) content for a slot, to be rendered only when no content is provided. For example, in a <submit-button>
component:
We might want the text “Submit” to be rendered inside the <button>
most of the time. To make “Submit” the fallback content, we can place it in between the <slot>
tags:
Now when we use <submit-button>
in a parent component, providing no content for the slot:
2 Slots Ac
will render the fallback content, “Submit”:
But if we provide content:
Then the provided content will be rendered instead:
Named Slots
Updated in 2.6.0+. See here for the deprecated syntax using the slot
attribute.
There are times when it’s useful to have multiple slots. For example, in a <base-layout>
component with the following template:
For these cases, the <slot>
element has a special attribute, name
, which can be used to define additional slots:
A <slot>
outlet without name
implicitly has the name “default”.
To provide content to named slots, we can use the v-slot
directive on a <template>
, providing the name of the slot as v-slot
‘s argument:
Now everything inside the <template>
elements will be passed to the corresponding slots. Any content not wrapped in a <template>
using v-slot
is assumed to be for the default slot.
However, you can still wrap default slot content in a <template>
if you wish to be explicit:
Either way, the rendered HTML will be:
Note that v-slot
can only be added to a <template>
(with one exception), unlike the deprecated slot
attribute.
Scoped Slots
Updated in 2.6.0+. See here for the deprecated syntax using the slot-scope
attribute.
2 Slots 3080
Sometimes, it’s useful for slot content to have access to data only available in the child component. For example, imagine a <current-user>
component with the following template:
We might want to replace this fallback content to display the user’s first name, instead of last, like this:
That won’t work, however, because only the <current-user>
component has access to the user
and the content we’re providing is rendered in the parent.
To make user
available to the slot content in the parent, we can bind user
as an attribute to the <slot>
element:
Attributes bound to a <slot>
element are called slot props. Now, in the parent scope, we can use v-slot
with a value to define a name for the slot props we’ve been provided:
In this example, we’ve chosen to name the object containing all our slot props slotProps
, but you can use any name you like.
Abbreviated Syntax for Lone Default Slots
In cases like above, when only the default slot is provided content, the component’s tags can be used as the slot’s template. This allows us to use v-slot
directly on the component:
This can be shortened even further. Just as non-specified content is assumed to be for the default slot, v-slot
without an argument is assumed to refer to the default slot:
Note that the abbreviated syntax for default slot cannot be mixed with named slots, as it would lead to scope ambiguity:
Whenever there are multiple slots, use the full <template>
based syntax for all slots:
Destructuring Slot Props
Internally, scoped slots work by wrapping your slot content in a function passed a single argument:
That means the value of v-slot
can actually accept any valid JavaScript expression that can appear in the argument position of a function definition. So in supported environments (single-file components or modern browsers), you can also use ES2015 destructuring to pull out specific slot props, like so:
This can make the template much cleaner, especially when the slot provides many props. It also opens other possibilities, such as renaming props, e.g. user
to person
:
You can even define fallbacks, to be used in case a slot prop is undefined:
Dynamic Slot Names
New in 2.6.0+
Dynamic directive arguments also work on v-slot
, allowing the definition of dynamic slot names:
Named Slots Shorthand
New in 2.6.0+
Similar to v-on
and v-bind
, v-slot
also has a shorthand, replacing everything before the argument (v-slot:
) with the special symbol #
. For example, v-slot:header
can be rewritten as #header
:
However, just as with other directives, the shorthand is only available when an argument is provided. That means the following syntax is invalid:
Instead, you must always specify the name of the slot if you wish to use the shorthand:
Other Examples
Slot props allow us to turn slots into reusable templates that can render different content based on input props. This is most useful when you are designing a reusable component that encapsulates data logic while allowing the consuming parent component to customize part of its layout.
For example, we are implementing a <todo-list>
component that contains the layout and filtering logic for a list:
Instead of hard-coding the content for each todo, we can let the parent component take control by making every todo a slot, then binding todo
as a slot prop:
Now when we use the <todo-list>
component, we can optionally define an alternative <template>
for todo items, but with access to data from the child:
However, even this barely scratches the surface of what scoped slots are capable of. For real-life, powerful examples of scoped slot usage, we recommend browsing libraries such as Vue Virtual Scroller, Vue Promised, and Portal Vue.
2 Slots Rtx 3080
Deprecated Syntax
The v-slot
directive was introduced in Vue 2.6.0, offering an improved, alternative API to the still-supported slot
and slot-scope
attributes. The full rationale for introducing v-slot
is described in this RFC. The slot
and slot-scope
attributes will continue to be supported in all future 2.x releases, but are officially deprecated and will eventually be removed in Vue 3.
Named Slots with the slot
Attribute
Deprecated in 2.6.0+. See here for the new, recommended syntax.
To pass content to named slots from the parent, use the special slot
attribute on <template>
(using the <base-layout>
component described here as example):
Or, the slot
attribute can also be used directly on a normal element:
There can still be one unnamed slot, which is the default slot that serves as a catch-all for any unmatched content. In both examples above, the rendered HTML would be:
Scoped Slots with the slot-scope
Attribute
Deprecated in 2.6.0+. See here for the new, recommended syntax.
To receive props passed to a slot, the parent component can use <template>
with the slot-scope
attribute (using the <slot-example>
described here as example):
Here, slot-scope
declares the received props object as the slotProps
variable, and makes it available inside the <template>
scope. You can name slotProps
anything you like similar to naming function arguments in JavaScript.
Here slot='default'
can be omitted as it is implied:
The slot-scope
attribute can also be used directly on a non-<template>
element (including components):
The value of slot-scope
can accept any valid JavaScript expression that can appear in the argument position of a function definition. This means in supported environments (single-file components or modern browsers) you can also use ES2015 destructuring in the expression, like so:
Using the <todo-list>
described here as an example, here’s the equivalent usage using slot-scope
:
Summary :
There are different slots that you can choose, such as SATA, but the most popular slot now is the M.2 slot. Then what is an M.2 slot and what can it do? In this post, MiniTool provides you with detailed information about the M.2 slot.
What Is an M.2 Slot?
To begin with, what is an M.2 slot? The M.2 format, formerly known as Next Generation Form Factor (NGFF), is technically a replacement for the mSATA standard, which was very popular among manufacturers of ultra-compact laptops and other small accessories. The M.2 format is specially designed for manufacturers to replace various specific devices.
What Can M.2 Slot Do?
M.2 may completely replace all aging Serial ATA formats. The M.2 slot can interface with SATA 3.0 (the cable that may be connected to the storage drive of the desktop), PCI Express 3.0 (the default interface for graphics cards and other major expansion devices), and even USB 3.0.
This means that maybe any storage or disk drive, GPU or port extension, or low-power gadget using USB connection can be installed on the card that plugs into the M.2 slot at the same time. But the actual situation is much more complicated.
When you are using the PCI bus instead of the SATA bus, depending on the function of the motherboard and the M.2 card itself, M.2 devices can transfer data 50% to about 650% faster than standard SATA.
If you have the opportunity to use an M.2 SSD on a motherboard that supports PCI third generation, its speed may be much faster than conventional SATA drives.
What Devices Use the M.2 Slot?
Currently, M.2 is mainly used as an interface for ultra-high-speed SSDs on laptops and desktops. Some laptop designs also adopt the M.2 port as a wireless connection. This is not very common for desktop computers, which generally prefer to use a USB dongle or PCIe 1x card (although there is no reason why you cannot do this on a compatible motherboard).
And some companies have begun to expand the use of M.2 slots to categories that are not suitable for storage or expansion. Although no one has yet manufactured an M.2 graphics card, Intel is selling its Optane, a speed-up cache storage device in M.2 format, to consumers.
Does Your Computer Have an M.2 Slot?
If your PC was manufactured or assembled in recent years, it may have an M.2 slot. Unlucky, the flexibility of the format means that using it is not as easy as inserting a card.
The M.2 card has two main compatibility variables: length and key. The first one is obvious - your computer needs to have enough physical space to support the length of the card you want to use. The second is variable - the card’s connector must match the slot you want to insert.
Can You Add an M.2 Card If Your Computer Doesn’t Have an M.2 Slot?
If you are using a laptop, then you can't. The design of modern laptops is so compact that there is no room for unplanned expansion. If you use a desktop computer, then it’s OK for you. Adapters sold in large quantities already use the PCIe x4 slot on your motherboard.
However, if your motherboard cannot boot from PCIe, then you cannot set the M.2 drive as the boot drive, which means you will not benefit from a lot of speed. So you should know that if you want the full advantages of the M.2 hard drive, you may need a motherboard that supports this motherboard.
If you don’t know how to boot from M.2 SSD, this post is what you need. This post demonstrates how to install Windows 10 on M. 2 SSD and how to boot from M.2.
2 Slots For Med Bins
Bottom Line
This post has given you most information about the M.2 slot, such as what it is and what it can do. If your laptops don’t have an M.2 slot, then you cannot add an M.2 card. But you can do that if you are using desktops.