> 웹 프론트엔드 > JS 튜토리얼 > js 코드는 vue 양방향 데이터 바인딩 예제를 구현합니다.

js 코드는 vue 양방향 데이터 바인딩 예제를 구현합니다.

小云云
풀어 주다: 2018-02-24 14:20:19
원래의
2622명이 탐색했습니다.

양방향 데이터 바인딩 인터뷰에서는 일반적으로 먼저 접근자 속성의 사용법과 시간 관계를 이해해야 합니다. 먼저 코드를 붙여넣고 시간이 있을 때 분석해 보세요. 이 글이 모든 분들께 도움이 되기를 바랍니다.

1

2

3

4

5

6

Object.defineProperty(obj,propertyName,{                get:function(){

                    //读取obj对象的propertyName属性时执行

                },                set:function(currvalue){

                    //修改obj对象的propertyName属性时执行

                },

            });

로그인 후 복사

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>js实现vue双向数据绑定 利用访问器属性</title></head><body>

    <input bind-value="value" type="text" placeholder="请输入..."  id="user-input">

    <p bind-text="value" id="show-input"></p>

    <script>

    var elems=[document.getElementById(&#39;user-input&#39;),document.getElementById(&#39;show-input&#39;)];        var data={

            initValue:&#39;&#39;,

        };        function define(obj,propertyName) {

            Object.defineProperty(obj,propertyName,{

                get:function(){

                    return this.initValue;

                },

                set:function(currvalue){

                    this.initValue=currvalue;                    //同步p

                    scan();

                },

            });

        }

 

        define(data,&#39;value&#39;);

        data.value=&#39;&#39;;

        scan();        //监听事件

        elems[0].addEventListener(&#39;keyup&#39;,function(e){

            var e=e||window.event;

            data.value=e.target.value;

        });        function scan(){

            for(var i=0;i<elems.length;i++){                var ele=elems[i];                for(var j=0;j<ele.attributes.length;j++){                    var attr=ele.attributes[j];                    if(attr.nodeName.indexOf(&#39;bind&#39;)>=0){

                        elems[1].innerHTML=data.value;

                        elems[0].setAttribute(&#39;current-values&#39;,data.value);

                    }

                }

            }

        }    </script></body></html>

로그인 후 복사

관련 권장 사항:

Vue 양방향 데이터 바인딩 소스 코드 분석

양방향 데이터 바인딩을 구현하는 JS 방법

프런트 엔드에서 JS 양방향 데이터 바인딩

위 내용은 js 코드는 vue 양방향 데이터 바인딩 예제를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿