不前后端分离写 VUE,页面是不是会有多个 createApp 行为? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Felldeadbird
V2EX    Vue.js

不前后端分离写 VUE,页面是不是会有多个 createApp 行为?

  •  
  •   Felldeadbird 2021-05-29 22:13:03 +08:00 3903 次点击
    这是一个创建于 1610 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近在尝试写 VUE,因为旧项目无法做到前后端分离,依旧是基于后端渲染模板模式。

    一般项目,会分 页眉、侧栏,内容和页脚。在后端来说,这几块拆分好,然后用 JQ 去写一套逻辑即可。

    我尝试用 VUE 去编写,VUE 要求在 createApp({...数据逻辑..}) 中就要声明好了。如果我用到 element UI 的布局划分,

    //先注册页眉 header = Vue.createApp({..逻辑和组件..}).use('ElementPlus').mount('#header'); //在注册侧栏 sidebar = Vue.createApp({..逻辑和组件..}).use('ElementPlus').mount('#sidebar'); //最后注册布局 app = Vue.createApp({..逻辑和组件..}).use('ElementPlus').mount('#app'); 

    这是其中一个解决办法,还有另外一种,组件

    //在页眉文件 header.php 声明 <script> const app = Vue.createApp({}); app.use(ElementPlus); app.component('header', {}) </script> //sidebar.php 侧栏 <script> app.component('sidebar', {}) </script> //content.php 内容 <script> app.component('sidebar', {}) </script> //footer.php 页脚 <script> app.mount("#app"); </script> 

    感觉很别扭,因为我要将后端的模板变量,转换为 Javascript 的标量,数组或对象。

    不知道有没有后端有其他更优雅的解决办法呢?

    11 条回复    2021-06-01 10:00:12 +08:00
    Roxk
        1
    Roxk  
       2021-05-29 23:12:37 +08:00   1
    后端渲染时,把前端所需要的数据挂在一个全局变量上(比如 window.__pagedata_header={data:1};window.__pagedata_sidebar={data:1}),然后前端在一个 script 里去拿 window.__pagedata_header 和 window.__pagedata_sidebar 塞进 createApp 中,不知道是否可以?
    zhyt0520
        2
    zhyt0520  
       2021-05-30 00:45:25 +08:00
    建议参考 inertiajs
    https://inertiajs.com/
    echowuhao
        3
    echowuhao  
       2021-05-30 01:32:30 +08:00   1
    可以考虑 vue 的弟弟 https://github.com/alpinejs/alpine
    xiaomingVTEX
        4
    xiaomingVTEX  
       2021-05-30 01:37:49 +08:00   1
    IvanLi127
        5
    IvanLi127  
       2021-05-30 09:51:47 +08:00 via Android   1
    我觉得无法分离的,还想直接上 vue,直接把页眉页脚内容什么的全丢到一个 div 下面 然后 vue 挂这个 div 就好了。。。另外有多个 vue 实例也不是什么问题吧
    rykinia
        6
    rykinia  
       2021-05-30 10:08:20 +08:00   1
    用 vue 的组件是正确的方式,但应该写一个 main-page.vue ,然后用 vue 自己引入 component/header.vue, component/siderbar.vue 等组件,页面完全由 vue 管理,后端只负责提供数据。而不是依然用后端来分别 include.
    rykinia
        7
    rykinia  
       2021-05-30 10:19:16 +08:00
    @rykinia 突然想起来这是前端打包的写法,无视吧 -.-
    xiaoyiyu
        8
    xiaoyiyu  
       2021-05-30 22:11:33 +08:00 via iPhone   1
    不用吧,前后端不分离但是可以分离 js 文件,js 文件写在 php 之外。如果有后端生成的 js 变量,定义在 php 的 script 标签里,分离的 js 放在最后引入就可以吧
    Felldeadbird
        9
    Felldeadbird  
    OP
       2021-05-30 22:28:50 +08:00
    @xiaoyiyu 这个做法考虑过。要提前写好总提的 JS 方法,不然其他人接手维护,改动起来很容易出现 BUG 。
    Rache1
        10
    Rache1  
       2021-05-31 09:25:22 +08:00
    @zhyt0520 感觉这种开发方式很奇怪 虽然现在在用类似的
    TomVista
        11
    TomVista  
       2021-06-01 10:00:12 +08:00   1
    <div id='app'>
    <template />
    </div>

    <script>

    const data = %data%

    new Vue({
    el: "#app",
    data,
    methods:{}
    }
    </script>
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2615 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 34ms UTC 14:48 PVG 22:48 LAX 07:48 JFK 10:48
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86