V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
laaaaaa
V2EX  ›  问与答

小白学 Vue, 一些编写规范问题,想请教一下

  •  1
     
  •   laaaaaa · 160 天前 · 1035 次点击
    这是一个创建于 160 天前的主题,其中的信息可能已经有所发展或是发生改变。

    环境

    vue3 + vite + js + css3 ; (学 VUE 2 周)

    疑问 1 ;

    假如我自定义一个组件 名字叫 MenuItem.vue 我在一个 Vue 文件里引入,那我使用这个组件 应该是?

    1 <MenuItem /> 2 <MenuItem> <MenuItem/> 3<menu-item /> 4 <menu-item> <menu-item/>

    ps: 我在 vue3 官网看到这段话 每太理解;

    在单文件组件中,推荐为子组件使用 PascalCase 的标签名,以此来和原生的 HTML 元素作区分。虽然原生 HTML 标签名是不区分大小写的,但 Vue 单文件组件是可以在编译中区分大小写的。我们也可以使用 />来关闭一个标签.
    
    如果你是直接在 DOM 中书写模板 (例如原生 <template> 元素的内容),模板的编译需要遵从浏览器中 HTML 的解析行为。在这种情况下,你应该需要使用 kebab-case 形式并显式地关闭这些组件的标签.
    

    疑问 2 ;

    在写项目的时候,目录结构怎么算是标准的,如文件夹名称,文件名称,组件名称,样式名称,布局组件?

    举例: 我的 vue3 项目,src 下有,api,assets,components,layout,style,router,views;

    components 和 layout 下,新建组件,比如一个 MenuItem.vue ,是建一个 MenuItem 文件夹里创建 index.vue ,还是直接建文件? 文件夹名称 和 文件名称 是否需要是驼峰 + 首字母大写? components 和 layout 下 的组件命名有区别吗?

    css 的布局的文件,是单独放到 style 里 还是放到 assets 下,怎么算是标准的,我看一些大佬的 vue3 项目,他们写有的 scss 是 _xxxx.scss 还有 xxxx_.scss 命名有什么标准吗?

    ps: 就是想问问,vue3 有没有说像 Java 有阿里巴巴开发规范手册一样,来规范标准化这些东西? 我参考了很多开源 基本都是按照自己的风格写的;

    10 条回复    2024-07-05 15:27:50 +08:00
    vueli
        1
    vueli  
       160 天前
    我的目录:
    views
    fileList
    components
    model
    index.vue / xxx.vue

    至于 css 提取出来全看个人,这无所谓,你写在一个文件里面,也能开两屏。 如果是.tsx 就需要外部引入了。

    终于你其他的问题,完全取决你接手的项目之前的人怎么写的。

    你要是真想弄一套规范,直接去看开源的 github start 数量巨多的那种,抄规范就行了。
    vueli
        2
    vueli  
       160 天前
    views
    ---fileList
    ------components
    ------model
    ------index.vue / xxx.vue
    zhhbstudio
        3
    zhhbstudio  
       160 天前   ❤️ 1
    15 ,16 年开始写 Vue ,到目前自己也乱七八糟瞎写。。。

    答疑问 1:
    1: <MenuItem/>;
    2:<MenuItem></MenuItem>;
    3:<menu-item />.
    4:<menu-item></menu-item>;
    应该都是能正常用的。(注意 / 的位置,html 关闭标签 / 在前边。)
    没有子元素时,可以使用 1 ,3 。但是 2 ,4 也是正常的。有子元素只能使用 2 ,4 。
    第二段引用的意思应该是有运行时用到的模板(不经过 node 编译的),只能使用 4 这种。

    答疑问 2:
    我目前的习惯就是全项目统一就行,怎么开心怎么来。。。。
    你要找到也分享给我一份吧。

    有其他疑问也可以随时交流,正好我也回顾回顾忘记的或之前忽略的东西。
    zhhbstudio
        4
    zhhbstudio  
       160 天前
    @zhhbstudio

    补充:css ( scss )共享的放 assets ,不共享的直接写在 vue 文件内
    xubingok
        5
    xubingok  
       160 天前
    回答第一个:
    用<MenuItem> <MenuItem/>或者<MenuItem />.取决于有没有子元素.

    vue 已经支持 PascalCase 类型了,没必要再转一下.组件的属性同理.
    jones2000
        6
    jones2000  
       160 天前
    关键是有注释, 需求文档,设计文档,每次提交代码备注的时候把改动内容写全。
    v21984
        7
    v21984  
       160 天前   ❤️ 1
    不要用 <menu-item /> 这种写法,一点都不方便后续别人接手时搜索
    laobobo
        8
    laobobo  
       159 天前
    我一般保持和文件名一致,方便检索
    fusi
        9
    fusi  
       159 天前
    规范的话,最简单的方式就是去 github 上找一些 vue 项目,看看他们怎么写的、怎么划分文件结构的,可以跑起来,然后给自己提几个需求,这样能最快帮助你深入,也能更好的理解为什么这样写
    实际工作中,大多数时候都是 curd ,在现有的项目上改,所以我的理解是,你暂时不需要操心目录结构的事,见多了,写多了,就有自己的一套理解与规范了
    gzyguy
        10
    gzyguy  
       159 天前
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5336 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 01:40 · PVG 09:40 · LAX 17:40 · JFK 20:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.