What is the meaning of the words template:' < App/ > 'and components: {App} in vue?

Where is the App variable defined in

components: {App}? isn"t there only one App.vue file name? No App variable found! In vue"s todo-list example, the b of components is written like this: components: {"signature": variable name}, such as components: {"todo-list":TodoList}, where components: {App}, there is neither label nor variable, how do you understand it?
is also written in template: template:"< App/ >". What should be defined in template is a tag. I would like to ask, where is the < App > tag? There doesn"t seem to be this label!

Jul.29,2021

  1. the components: {App} you mentioned should be in the main.js entry file, so the App should be exported from the App.vue component through export default, and then the App variable should be imported through import in main.js
  2. .
  3. components: {App} is written as ES6. In an object, if the key-value pair is the same, only one can be written
  4. .
  5. template:'< App/ > 'also involves an abbreviated processing. If you don't add attributes or instructions to the component, you can write it in the form of a tag. < App/ > is actually' < App > < App/ >'
  6. . Where is the
  7. < App > tag? < App > this means that the APP component template:'< App/ > 'represents the template that uses the APP component

the above is for personal understanding. If there is anything wrong, you are welcome to beat the bricks

.

vue template syntax goes like this:

html:
<div id='app'>
    <!-- ! -->
    <test></test>
</div>

js:
new Vue({
    components: {
        //  test 
        test: {
            template: '<div class="test"> test </div>'
        }
    }
});

the above should be understood at a glance. What you don't understand is the code that uses ES6+ (including) syntax:

// 
let App = {
    template: '<div></div>'
}:

new Vue({
    // template  html
    //  App 
    // 
    // <App />  <App></App>
    template: '<App />'
    components: {
        // es6 , 
        App
    }
});

ES6+ syntax-Ruan Yifeng


@ jzsn Thank you for answering! With regard to the fourth point of your answer, I still don't understand whether the < App > tag is the content of the template in the App component (App.vue).

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-41fa0ed-99f.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-41fa0ed-99f.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?