Skip to content

Sticky

Sticky layout component, used to fix elements at a specified position when the page scrolls.

Basic Usage

Simply wrap the content that needs to be sticky in the wd-sticky component.

Note: Using percentage units width:xx%;height:xx%; in the style of wrapped elements is invalid. It's recommended to use vh, vw instead.

html
<wd-sticky>
  <wd-button type="success">Basic Usage</wd-button>
</wd-sticky>

Dynamic Insertion

wd-sticky supports wrapping dynamically generated content.

Note: When wrapping dynamically generated content, ensure the content's width and height are not less than 1px

html
<view style="margin-top: 20px;">
  <wd-button type="error" v-if="show">Click to Insert</wd-button>
  <wd-sticky>
    <wd-button type="success" v-if="show">Dynamic Insert</wd-button>
  </wd-sticky>
</view>
typescript
const show = ref<boolean>(false)

function display() {
  show.value = true
}

onShow(() => {
  setTimeout(display, 5000)
})
scss
page{
  height: 200vh;
}

Offset Top

You can set the distance between the component and the top when it's sticky using the offset-top property.

Reminder

Since the navigation bar in H5 is a regular element, the sticky distance will automatically increase by 44px based on offset-top. When developers use a custom navigation bar in H5, offset-top needs to be reduced by 44. For example, if you want a sticky distance of 20px, then offset-top = 20 - 44 = -24

html
<wd-sticky :offset-top="50">
  <wd-button>Offset Top</wd-button>
</wd-sticky>

Specify Container

Wrap the wd-sticky component inside a custom container, then wrap the custom container with wd-sticky-box.

Note: Using percentage units width:xx%;height:xx%; in the style of the wrapped custom container is invalid. It's recommended to use vh, vw instead.

html
<wd-sticky-box>
  <view class="container">
    <wd-sticky>
      <wd-button type="warning">Specify Container</wd-button>
    </wd-sticky>
  </view>
</wd-sticky-box>
scss
.container{
    height: 150px;width: 100vw;
}

Sticky Attributes

ParameterDescriptionTypeOptionsDefaultVersion
z-indexStack ordernumber-1-
offset-topDistance from top when stickynumber-0-

Sticky External Style Classes

Class NameDescriptionVersion
custom-classRoot node style-

Source Code

Documentation
Component

Released under the MIT License.

Released under the MIT License.