| 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>
 |