title | name | permalink |
---|---|---|
PlatformRuntime |
platform-runtime |
/packages/modules/platform-runtime |
Runtime shims and compiletime plugins for smoothing out differences between platforms.
import TransitionPrimitive from '@mand-mobile/platform-runtime/lib/component/transition'
- show: Boolean, default:
false
- name: String
- styles: Object
- beforeEnter
- enter
- afterEnter
- beforeLeave
- leave
- afterLeave
import ScrollViewPrimitive from '@mand-mobile/platform-runtime/lib/component/scroll-view'
- scrollingX: Boolean, default:
false
- scrollingY: Boolean, default:
true
- height: [Number, String], default:
'auto'
- refresherEnable: Boolean, default:
false
- endReachedThreshold: Number, default:
0
- styles: Object
- refreshing
- end-reached
- scroll, params: { scrollTop, scrollLeft }
- reflowScroller
- getSizes: () => { wrapperW, wrapperH, contentW, contentH }
- getOffsets: () => { left, top }
- scrollTo: (left: number, top: number, isAnimation = false) => void
- triggerRefresh
- finishRefresh
- finishLoadMore
import toastFactory from '@mand-mobile/platform-runtime/lib/component/toast'
- toastFactory: ToastOptions: VueOptions => Toast
import dialogFactory from '@mand-mobile/platform-runtime/lib/component/dialog'
- dialogFactory: DialogOptions: VueOptions => Dialog
import actionSheetFactory from '@mand-mobile/platform-runtime/lib/component/action-sheet'
- actionSheetFactory: ActionSheetOptions: VueOptions => ActionSheet
import {Dom} from '@mand-mobile/platform-runtime/lib/module'
const $MDDom = Dom.bind(this) // scoped selector like refs
$MDDom().querySelector('xxxx').getScrollOffset()
documentElement(): nodeRef
uniapp返回的是可视区域实例 查看详情
$MDDom().documentElement()
querySelector(elNmae: string): nodeRef
export default {
async mounted () {
const testNodeRef = this.$MDDom().querySelector('.test')
const rect: DOMRect = await testNodeRef.getBoundingClientRect()
}
}
querySelectorAll(elNmae: string): nodeRef
uniapp中返回的不是真实数组,所以不能直接用length等属性,需调用getNode方法
export default {
async mounted () {
const firsttTestNodeRef = this.$MDDom().querySelector('.test')[0]
const rect: DOMRect = await firsttTestNodeRef.getBoundingClientRect()
}
}
getNode(): Promise<any[]>
web中不做处理直接返回dom节点,uniapp支持Canvas节点的获取 查看详情
const nodeRefs = $MDDom().querySelectorAll('.test')
const nodes = await nodeRefs.getNode()
console.log(nodes) // [node, node, ...]
const nodeRef = $MDDom().querySelector('.test')
const node = await nodeRefs.getNode()
console.log(node)
getAttribute(prop: string): Promise<any>
uniapp中只能查询id或者nodesRef.fields方法中properties中可查询属性
export default {
async mounted () {
await $MDDom().querySelector('.test').getAttribute('id')
}
}
getBoundingClientRect(): Promise<DOMRect>
export default {
async mounted () {
await $MDDom().querySelector('.test').getBoundingClientRect()
}
}
getScrollOffset(): Promise<{scrollLeft: number, scrollTop: number }>
export default {
async mounted () {
await $MDDom().querySelector('.test').getScrollOffset()
}
}
getComputedStyle(propList: Array<string>): Promise<object>
export default {
async mounted () {
await $MDDom().querySelector('.test').getComputedStyle(['position'])
}
}
import {Device} from '@mand-mobile/platform-runtime/lib/module'
const device = Device()
device.vibrate()
or
export default {
mounted () {
$MDDevice().vibrate()
}
}
短时震动,仅在小程序真机有效,web和小程序调试工具无效