123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- <!-- 自定义页面:支持装修 -->
- <template>
- <s-layout
- :title="state.name"
- navbar="custom"
- :bgStyle="state.page"
- :navbarStyle="state.navigationBar"
- onShareAppMessage
- showLeftButton
- >
- <s-block v-for="(item, index) in state.components" :key="index" :styles="item.property.style">
- <s-block-item :type="item.id" :data="item.property" :styles="item.property.style" />
- </s-block>
- </s-layout>
- </template>
- <script setup>
- import { reactive } from 'vue';
- import { onLoad, onPageScroll } from '@dcloudio/uni-app';
- import DiyApi from '@/sheep/api/promotion/diy';
- const state = reactive({
- name: '',
- components: [],
- navigationBar: {},
- page: {},
- });
- onLoad(async (options) => {
- let id = options.id
- // #ifdef MP
- // 小程序预览自定义页面
- if (options.scene) {
- const sceneParams = decodeURIComponent(options.scene).split('=');
- id = sceneParams[1];
- }
- // #endif
- const { code, data } = await DiyApi.getDiyPage(id);
- if (code === 0) {
- state.name = data.name;
- state.components = data.property?.components;
- state.navigationBar = data.property?.navigationBar;
- state.page = data.property?.page;
- }
- });
- onPageScroll(() => {});
- </script>
- <style></style>
|