Detalles del uso de componentes (4-1)

Detalles del uso de componentes

El siguiente método tendrá errores
Inserte la descripción de la imagen aquí
sin tbody

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src='./vue.js'></script>
</head>
<body>
    <div id="root">
        <table>
            <tbody>
             <row></row>
             <row></row>
             <row></row>
            </tbody> 
        </table>
    </div>    
    <script>
        
        Vue.component('row', {
     
     
            template: '<tr><td>this is a row</td></tr>'
        })

        var vm = new Vue({
     
     
            el: '#root'
        })
    </script>
</body>
</html>

El método de modificación es el siguiente

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src='./vue.js'></script>
</head>
<body>
    <div id="root">
        <table>
            <tbody>
             <tr is="row"></tr>
             <tr is="row"></tr>
             <tr is="row"></tr>
            </tbody> 
        </table>
    </div>    
    <script>
        
        Vue.component('row', {
     
     
            template: '<tr><td>this is a row</td></tr>'
        })

        var vm = new Vue({
     
     
            el: '#root'
        })
    </script>
</body>
</html>

Generalmente, si define datos en un componente, debe devolver los datos con retorno

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src='./vue.js'></script>
</head>
<body>
    <div id="root">
        <table>
            <tbody>
             <tr is="row"></tr>
             <tr is="row"></tr>
             <tr is="row"></tr>
            </tbody> 
        </table>
    </div>    
    <script>
        
        Vue.component('row', {
     
     
            data: function() {
     
     
                return {
     
     
                    content: 'this is content'
                }
            },
            template: '<tr><td>{
     
     {content}}</td></tr>'
        })

        var vm = new Vue({
     
     
            el: '#root'
        })
    </script>
</body>
</html>

Las operaciones de dom se pueden realizar a través de etiquetas ref

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src='./vue.js'></script>
</head>
<body>
    <div id="root">
        <div
            ref='hello'
            @click="handleClick"
        >
            hello world
        </div>
    </div>    
    <script>
        
        var vm = new Vue({
     
     
            el: '#root',
            methods: {
     
     
                handleClick: function() {
     
     
                    console.log(this.$refs.hello.innerHTML)
                }
            }
        })
    </script>
</body>
</html>

Establezca el evento de clic en el componente, active el cambio y luego active handleChange para calcular la suma de las dos
referencias que se utilizan para marcar la operación dom.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src='./vue.js'></script>
</head>
<body>
    <div id="root">
        <counter ref="one" @change="handleChange"></counter>
        <counter ref="two" @change="handleChange"></counter>
        <div>{
   
   {total}}</div>
    </div>    
    <script>
        
        Vue.component('counter', {
     
     
            template: '<div @click="handleClick">{
     
     {number}}</div>',
            data: function() {
     
     
                return {
     
     
                    number: 0
                }
            },
            methods: {
     
     
                handleClick: function() {
     
     
                    this.number++
                    this.$emit('change')
                }
            }
        })

        var vm = new Vue({
     
     
            el: '#root',
            data: {
     
     
                total: 0
            },
            methods: {
     
     
                handleChange: function() {
     
     
                    this.total = this.$refs.one.number + this.$refs.two.number
                }
            }
        })
    </script>
</body>
</html>

Supongo que te gusta

Origin blog.csdn.net/weixin_45647118/article/details/113927162
Recomendado
Clasificación