-
Notifications
You must be signed in to change notification settings - Fork 4.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Style Guide] Outdated styleguide - it's about time #2565
Comments
@Nagell just to make it clear: you would like to see a new section in the styleguide that would recommend how to structure the code written with Composition API in |
@NataliaTepluhina the short answer is: yes. Composition API gives so much freedom that sometimes it's hard for me to tell if it's not to much 😅 Btw. I could swear I saw a red notice at the top of the style guide a few weeks ago that there are plans to add some rules for the composition API. Has anything changed there? I realized that my previous post was a bit tangled and way to emotional (sorry about that), so I'll try to break it up into more sections. Why bother at allOne could say that Composition API is for experienced users (docs mentions the Options API as more beginner-friendly). But there are many cases of a new person coming from another company and facing a new technology (Vue) and being forced to use Composition API right away. If we speak about a whole team of Backend guys approaching something done by a person which is not there anymore, it is a recipe for a disaster. In my case also this person wasn't a Vue dev, but rather a React?? dev forced to write Vue. Therefore some rules / tips about good practices around Composition API could be very helpful and save some headache. In some cases described below, we could ask if Vue should be made responsible for it at all, but we even put this phrase in the docs:
which is de facto the default choice for every company, no matter the experience of the coworkers with Vue or JS at all. It could also help provide a good first experience with our beloved framework for those who are forced to use the Composition API in their first attempt to learn Vue. At the end of the day, Vue is mostly chosen because of the rumor that it's easy to learn. But it should also be easy to maintain. Why <script setup> over setup()?By working with less experienced colleagues I realized that putting everything in the components: {
CustomerDialog
},
setup() {
const customerDialog = ref();
//...
customerDialog.value.show(customer.value);
//... you will end up with having access to everything which was put in the The whole
What other recommendations could be helpful?Not everything has to be a constIn the Options API there was a thing about using arrow functions in methods -> article but as const fillSelectedZipCode = async () => { //...
const handleSelectZipInput = (event) => { //...
const isKeyAccountChanged = () => { //...
// Well almost everything...
const fetchCityZipCodes = async function () { //... but not a single function something() { //... in an entire codebase. It makes the code way harder to read, as most of the time you have to read the whole line to find out if it's a When to split a componentOptions API is a good choice if the component should be small. If it's big the Composition API would be the way to go, as you are free to put everything in any order you like and it should be more readable. Well... till some point it is. I saw components with over 1500 lines of code (not counting style) which definitely should be split. Refs and functions all over the place. Tabs, Search, server communication and 'Domain specific conditional rendering' logic mixed with something which should rather be a state management in pinia. But why should we mention such basic good practice of code writing at all? When Composition API was created, the main reason for this was exactly this mentioned freedom of grouping features (which was encouraged and advised). As I mentioned earlier(#why-bother-at-all) it is the default choice for every big project, but as a side effect it made writing huge and very tangled components almost to easy. So maybe similar advice would be appropriate: |
@Nagell thank you for the detailed explanation, it's much appreciated (and the potato meme too xD). I think it's a reasonable request, although documenting good practices for Composition API won't be easy - giving a clear straightforward guidance on something that has this level of "freedom" is always tricky (besides I'll try to compose a few recommendations and run them through the team, any additional suggestions are very welcome! |
@NataliaTepluhina Thank you very much for your feedback. I really appreciate it. In the coming days I'll run it through again in my head. In case of any new ideas, I'll let you know :) |
@NataliaTepluhina I just realized that whit this another Pandora's box could be opened, but there is no mention of TS syntax in the style guide. For example in props rule this could be an additional recommendation for TS use cases: const Status = {
syncing: 'syncing',
synced: 'synced',
versionConflict: 'version-conflict',
error: 'error',
} as const
export interface ButtonProps {
status: typeof Status[keyof typeof Status]
}
const props = withDefaults(defineProps<ButtonProps>(), {
status: 'syncing',
}) Depending on the idea/case in this example, maybe an Btw. Did you have some time and the opportunity to throw some ideas on the team? If so, how did they reacted? I know it's not an easy topic and probably everyone has a bit another approach. I'm excited to hear what you've come up with. |
@pikax is probably the guy for some TS-heavy docs improvements. 😋 |
Maybe I am already 👀 #2577 As a composition-API + TS "connoisseur" myself 😆 I think composition-api is just simpler on small components in comparison with options-api.
"Composition API is for experienced users" - I cannot find that mentioned in the docs, you could possibly deduce it based on the statement "The Options API... It is also more beginner-friendly", but just because Options-API is more beginner friendly, it does not mean Composition-API is for experienced users only. If a company or someone started a project and decided in using composition-api and then a new person comes in and is faced with a new technology "forced" on them, I don't really think is Vue responsibility to do something about it, since that's the company/person decision to do it in composition-api and then it was the company decision to hire someone not familiar with the technology to maintain it, you can make the exact same argument with the same technology, I don't think this is composition-api or vue docs fault.
I agree with the docs, the goal for composition-api was to bring better tools for bigger projects, since Vue started to be used in bigger and bigger projects, Options-API is IMO inferior for those projects. Companies probably start with composition-api with the expectation the project become bigger and bigger over time.
I personally think Vue, especially since v3 is aimed for more complex usages, whilst still maintaining the same simple API that myself found in love with, but as the tech evolves and the ecosystem also evolves, we need to adapt and decide on what tech to use for projects.
Exposed variables must be used careful, but the same argument is also valid in OptionsAPI, since everything is automatically exposed to whoever needs to change it, so not sure where this fits into Composition-API caused issue 🤔
I mean there's actual differences between arrow and function, if the differences are not a blocker, it just becomes a mater of syntax preference.
Not sure if I understand, ever since the composition-api was introduced this picture has been used, not sure where is easier to tangle features (seen here): Don't forget the biggest advantage of Composition-API is composables, which allows you to move a domain or functional to a composable function built to be reusable and easy to test, see VueUse Bad code will be written regardless of how good the framework or tools being used :D |
This is what I was referring to indeed. 😉 |
@pikax Thank you for your time and answer and up front: sorry for another long post.
That's cool :)
They brought it onto themselves. A bunch of backend/fullstack devs asked external consultants, what would be the easiest approach to meet their company needs. They never worked before with reactive frameworks. That's why they have got into Vue - because it has a reputation of being easy to learn and having a mild learning curve. As we seemingly agree, it is to be expected that they will opt for the composition-API if the project should grow over time. And you are right, framework don't have to be responsible for being newbe friendly. But till the v3 it was its strength and it was the reason for many companies why they adapted Vue even if they had other good alternatives. The clue of my call is the feeling that during the evolution of the ecosystem docs became somewhat confusing to the newcomers. V2 was indeed easy to learn and due to more opinionated approach it was also easier to learn good practices. In v3 there are at least three ways of writing components (not even including the + 'TS' variant), whereas two of them are intertwined in the docs ( Many companies will start not having much experience and directly using composition-API, driven by a good reputation of the framework. I saw this pattern couple of times. If Vue want to keep its reputation, docs should not only concentrate on people having v2 background, but also take care of the new guys starting directly with the v3. Maybe it's not even about the Style Guide itself. Maybe it should be 'Best Practices' and 'How to structure your project and code'? Or 'How to solve common SPA problems with Vue':
In other words: 'how to make my code DRY in a typical app and not die buried under a bunch of repetitions and endless props-emits chains'? Because this is what I see every time when someone is starting with Vue. Their fault? Company fault? Maybe... But maybe we could take care of it, like the others:
If you are googleing 'best practices vue' you will find outdated 'Style Guide' for v2 and even if you will somehow find v3 it's mostly about syntax. 'How to keep it DRY', 'way of thinking' or 'project structuring' are not mentioned at all. Right now when someone is asking me 'Where should I start?', the answer is 'Vue School' or 'Vue Mastery'. Shouldn't it be rather: 'just go to the docs. It will take you through all basics and best practices in no time'? I think I can save us a bit of time not going into every detail. I don't want to argue over personal preferences. Many of my thoughts were only samples. I just hope that we can keep up with a the biggest strength of the ecosystem (at least till recenlly):
Not 'to many choices and easy to create a need for refactoring', because this leads to bad DX.
This is concerning. Just to clarify:
In this case I compared setup() and <script setup>. The first one forces you to expose everything to the outside world even if you just want to use it in the . In the second one you have to be explicit about it and without
Not sure if it sarcasm, but as I mentioned I saw many way to big components. If they should follow this picture they would have to end up with many My rule of thumbs would be: if I'm loosing the overview and feel that another setup() function is needed, then my component is probably to big and something should be: split and put somewehre else (smaller somponents, store, reusables, helpers). But maybe I am wrong?
I saw little push towards Reusables and VueUse is in my experience known only to experienced guys as Docs barley mentions it. Such essential part could be mentioned more often. It could also be a part of 'Recommended / Good practices'. |
So far, this is more of a human problem and the need for more communication/better decision making etc, not a framework responsibility. If people are biased or not experienced enough, they should probably reconsider it and talk to FE experts. Learning to use is also quite relative overall. Really depends on the ecosystem/the community IMO. Thought about it but never knew how to implement it. Having some external website with questions/answers could be a good way but would also need to be maintained constantly. To have a proper search etc with it, it could be quite tricky. I'm working on a community project to kinda fill in the gaps there and maybe help some people improve together.
The v2 was IMO easier to learn because you could inspect a single piece of state and debug with it (something like
This, Vue3 is more flexible. Allows for more freedom. Hence, you need to actually know how to code properly and organize your codebase well. You are not constrained to 1 single way of writing it, hence you can do more advanced and better-organized patterns but at the same time, you can also make it crappier if you do not have some good foundations. Not really a Vue issue either, more of a JS or even coding fundamentals. Even people like Michael Thiessen, Lachlan Miller (etc...), or instructors from VueMastery/VueSchool can just give you a gist of a decent approach but that may not apply to your specific use-case or specific challenge. TLDR: being a good developer goes beyond some framework-specific knowledge. Vue can't find that one.
Future-proofing and playing it safe. Again, not Vue's responsibility IMO.
Some rules may help but again, common sense is required. And it depends on the company's needs/bandwidth in terms of human resources. Broad topic.
Using Nuxt is a decent start, if that fits your approach. Then, you could check some open-source projects built with it, like elk or any other one that may be complex enough to serve as an example. The examples from:
Nothing concerning here. Every JS framework will follow that trend after some time because the novelty wears off + you have always new things to try in our ecosystem. Trying the latest Marko, Solid or Qwik is more exciting than the old boring Vue that you've been working on for 5 years. Makes sense. Those are also stats and scoped to people who have submitted their results. Prone to bias and not representing the whole state of a given framework. If the % drops, that does not mean that it's becoming bad, there is more nuance to it.
Again, linters/conventions/code reviews/mentoring/good consulting/watching conferences/connecting with the community/taking some workshops or courses could help with those.
The point of this image is to explain that your code is grouped by what it does in CAPI, rather than being constrained into specific parts of your codebase. This way, you do not need to hop from Quoting the docs
Extracting the code to make it more reusable, versatile, and composable is your responsibility. It's just easier with CAPI because not forced to use mixins, have type inference etc...
Exactly. 👍🏻
VueUse is mentioned 4 times and on the proper pages IMO. If somebody does not go through the documentation more thoroughly, I guess it's on them. Also, a simple query on my side looks decent when it comes down to leading people towards being curious and checking what is Vueuse. The Stackoverflow answer on the image mentions VueUse. And if you're coming from any JS framework, you would grasp what it is immediately. If you don't, some people will tell you about it. Quite a lot of people are pushing a good amount of awareness around the tools available in the Vue ecosystem, on Twitter, LinkedIn, or other places on the Internet/real world. I do agree that some extra work could be done to polish it even more. But overall, some things are to be kept separate from the framework. When I was helping daily on Stackoverflow, I noticed a lot of people who could not use a |
Taking the example of TS, it's great to show how to use it in the context of Vue so that people know the basics of how to make them work well together. But going more in-depth is not a Vue concern, because you should learn TS by yourself before trying to make them work together. I am part of those people. Do I blame the Vue docs for it? There is only so much abstraction that you can add and you need a good middle-ground. Docs cannot fill all the gaps in those abstractions. Also coming from a guy who discovered GraphQL through some Apollo Nuxt module, was a hardcore ride to debug my issues (not a Nuxt docs or module issue). 😂 |
I surrender. It seems that the only option in your opinion is based on the assumption that people are generally passionate about frontend and its concepts, or at least want to master what they got into. Well... the only thing left for me is to tell my colleagues that there is no shortcut and that if they took a fullstack approach, that's their problem, not mine and not the frameworks either. ...although it is my problem, so I can only hope they take it seriously, otherwise I'm doomed to write tutorials and internal style guides for every typical problem and constantly check their commits. Maybe one day I'll publish it in some forgotten corner of the internet. I suppose that's why large companies with varying levels of knowledge among developers use more opinionated frameworks. Sadly, I don't have this option anymore. Maybe one day we will rewrite our projects or I will somehow manage to teach other five guys and surpass them in fixing their code. In any case, thank you for your time, the explanations for drops in the stats and presenting your take on that topic. At least my brain has something to work with :)
This indeed could help. Maybe this could be a place to publish my guides some day. Going back to thinking about, how to explain chaotic nature of the freedom given by pinia + props-emits and watchers to someone used to more linear Edit: I suppose this thread can be closed. Up to you guys. |
MO this issue has some merit, we are always open to get better documentation, but we need to know exactly what people think we are lacking. Just like in code, we must separate some of the concerns, Vue as a library is a tool to build web based apps, theres two main ways for you to build your app components, options-api and composition-api, you can use both in the same project, as you see fit. Vue it self just gives you the tools, you must know how to use the tool (that's valid for anything). Vue can be basically be broken down into two main parts, reactivity and rendering, the sfc is just a sugar for rendering to provide better DX. Everything outside that is placed elsewhere, router, store, SSR, builder, etc. Vue core as a project does not handle router directly nor it should, but the Vue-router is maintained by Core team members and other core libraries are also maintained by the core team, but they are not Vue core, they might have a mentioned in the docs but each project has their own docs. Nuxt and quasar are great examples of awesome libraries that are more opinated and do a lot of the heavy lifting for developers. Expecting pure backend developers transition to frontend without any bumps, is expecting a plumber do your house electrical wiring without any issues, they might know that is just cables in the house but don't know the details of each cable size, how many lines you need, etc. |
@Nagell Haha, I didn't mean to knife down the conversation, quite the opposite. Just wished to add a bit more nuance to the initial take of adding lots of documentation. 🤗 I am usually passionate about things, and think that might need to go all-in if I want to master something. A fullstack is also IMO not meant to specialize too deep into FE or BE but stay a bit more shallow like a jack of all trades. For people willing to learn, they will be pleased to do so by themselves I think! 😄 You are not obliged to write a piece of tutorial/etc for each situation every time by yourself. This could be a team effort + you could make it a pair-programming session or an in-office coaching day every X days/weeks by making a quick presentation of things you're doing as a team and that could be written in a better way. This will open a conversation and everybody could add their input, making it even more beneficial and efficient long-term.
No need to be a policeman. 👮🏻
Having more opinions is not always good, goes the opposite side of freedom. 😄
Yep, soft skills are important for that part but it may be worth the effort! Also, if people do not care about quality and just want to dump some code from 9-5 and then call it a day, you cannot change that for them. But again, it's a team thing where you would need some internal conversation as to how to improve things. 🤗 Tbh, the As @pikax said, improvement to the docs is always welcome. We just need to make it well. Also, every ecosystem takes a bit of time to get used to and discover new things. In our case, we are blessed with this kind of awesome list. If people are curious and wish to learn lots of things quite fast, this is still the best to have a quick overview of Vue's ecosystem without throwing out a BIG CHUNK of text in the middle of the documentation. 👍🏻 PS: I also understand your will, I've been there too (trying to push people into pouring a bit of their soul into improving our codebase), takes quite some effort but is usually worth it. That's a very kind and passionate move from your side for sure. 😌 |
@pikax In the course of this conversation, it crystallized quite clearly for me. Some sort of a help or FAQ page would be needed.
The vue-land or something similar could be an solution IMO. It already contains at least a couple of answers for the questions I presented here or asked myself in the last months, although some of them are still incomplete. @skirtles-code took definitely a good course. We can always say something like 'It depends' and then ask for that specific case someone is dealing with, but giving an answer like he did here... sort of 'it depends... In case X you could consider Y and in case of Z...' is just priceless. Btw. the last option presented there was something entirely new to me. Showing a bunch of options with their trade offs reduces the need of answering the same questions depending on the case on stack overflow for those willing to help. At the end, who knows better the trade offs, than those who were involved in creating the framework? And for those looking for the ideas all over the internet (blogs, dev.to, medium etc.) it saves a ton of time. I myself am getting astonishingly much time to make research and POCs, but not everyone is blessed with such opportunity during their working hours. Of course, an option to add questions and collect the most frequently asked ones would be even better. Later on other things could be added, migrated or whatever else, but for the beginning For now this would be my suggestion to empower his initiative:
What do you think? Yeah it surely will be bumpy, but it seems that I have no choice, but to turn the plumber into an electrician. A couple of times in fact xD |
@kissu Thank you for kind words and advice. I appreciate it. I created an internal Wiki and planned a bunch of Trainings & Tutorials - T'n'T 😄 I'm hoping for the best, but at the moment it looks like it's going to take a lot of effort to get our team up to a decent level as well as our entire codebase - it needs a lot of love and we have to rework every piece multiple times layer by layer. Plan is already there and first steps are under way.
In parallel our designer is working on a design library. For now I'am the only one responsible for making the FE better in terms of refactoring, doing mentioned T'n'T, programming the library with a Storybook and helping with the daily business. That's why I was reaching out, realizing that some of the questions are surely answered many times, but all I found were old things about v2. I wasn't sure if it was due to the nature of v3 or if it was just lacking, but figuring things out myself and hoping it was the best choice didn't seem like the best possible option to me. Thanks again for the advice. I think I might indeed find at least a few eager ones to help me, but it will take some time. Before it gets to that point, I'm on my own. But I will be still trying to level up my team and add this tiny brick to the vast community effort.😄 |
That was quite a coincidence but I bought The hardest part with those kinds of practice references is maintaining them (requires constant updates) + making them useful (add too much of those and it will just be noise because it is not easy to scan).
Sure haha. 😉 This is also where it can be tricky to find out what should be in the official documentation vs some other place. 🤔 Our dear @skirtles-code is either on holiday or more present on Discord. 😄 ~ GL for the TnT part! 🐢 ⚔️
SEO can definitely be a bit tricky with that one overall, even for Nuxt3 but that's why reaching out to the community in the first place can speed things up in the regard of "where to find the info". 🤗 Anyway, enjoy your end of 2023. 💚 |
Hi guys,
as you surely know, the style guide is quite outdated.
Vue 3 is there for a while.
<script setup>
is really great.I could even say that this is the most flexible, save and user friendly syntax, but there is no guide for it at all.
All in all the docs are giving me a vibe of
<script setup>
not being that interesting anymore.Maybe even docs itself are not the most interesting thing for dev team right now, but for newcomers they are!
This harms the image of once greatly documented mature ecosystem.
There is always more and more adoption in business, but it means at the same time that we have more and more
inexperienced colleagues trying to make something in vue from time to time. And they are producing spaghetti - lots of it.
Since the composition API we can put any amount of features in a single component and mix everything as we like,
but "with the great power comes..." - you know the drill.
Side note: I already regret this decision. At the end of the day we have two extremes:
(yes, i was there, saw it with my own eyes... and they still hurt)
I'm quite sure, that there are more experienced guys there to speak of the best practices.
Not trying to just toss a topic and run. Nothing like this. If I'll find a couple of 'I know the sh...'-guys I can gladly exchange ideas
and take responsibility for moderating it and writing it down.
Want to help? Maybe you know someone? Please, let me know.
In hope that it will get some traction,
kind regards
The text was updated successfully, but these errors were encountered: