> 웹 프론트엔드 > View.js > vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

WBOY
풀어 주다: 2021-12-27 19:07:03
앞으로
1973명이 탐색했습니다.

이 기사에서는 여러 Vue 객체, 전역 구성 요소 및 로컬 구성 요소를 인스턴스화하는 방법, 부모에서 자식으로 값 전달 등을 포함하여 Vue 구성 요소에 대한 관련 지식을 제공합니다. 모든 사람에게 도움이 되기를 바랍니다.

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

컴포넌트 애플리케이션에 대한 첫 소개

여러 vue 객체 인스턴스화

new를 사용하여 여러 vue 객체를 만들고 이름을 지정하면 변수를 통해 서로 액세스할 수 있습니다
예: 객체 2는 이름 변수를 수정합니다. 개체 1

<!-- 第一个根元素 -->
<div>这里是:{{name}}</div> 

<!-- 第二个根元素 -->
<div>
    <p>这里是:{{name}}</p>
<br>
    <button>change-one-name</button>
    <!-- 点击后修改vue-app-one的name值-->
</div>
로그인 후 복사
 // 第一个vue对象var one = new Vue({
    el:"#vue-app-one",
    data:{
        "name":"ccy1"
    }})

 // 第二个vue对象var two = new Vue({
    el:"#vue-app-two",
    data:{
        "name":"ccy2"
    },
    methods:{
        // 修改vue-app-one的name为'ccy333'
        changeName:function(){
            one.name = 'ccy333'
        }
    }})
로그인 후 복사

효과: 클릭한 후 "ccy1"을 "ccy333"으로 수정합니다

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

전역 구성 요소

정의 및 사용

  • 전역 구성 요소를 정의하려면 구성 요소 이름을 호출할 때 구성 요소 이름을 변경합니다. 태그 이름으로 사용되며, 이 태그에는 많은 하위 HTML 태그가 포함될 수 있습니다.
  • 이러한 하위 HTML 태그는 구성 요소의 템플릿 속성에 정의됩니다. 구성 요소가 호출될 때마다 템플릿의 태그가 렌더링됩니다
  • 템플릿 에는 루트 요소가 하나만 있어야 합니다
  • 구성 요소에서 data는 함수입니다 , 데이터를 반환합니다
  • 이 기능을 계속 사용할 수 있습니다 데이터에 정의된 데이터 호출

예:

구성 요소 정의:

① my-comComponent라는 구성 요소 정의
② 데이터 포함: 이름 및 메서드: ChangeName
③ 렌더링된 html 효과에는 p가 있습니다. 버튼을 클릭하면 이름이 수정됩니다
④ 네이밍 사양: camelCase(카멜 케이스 명명법) 및 kebab-case(하이픈 구분 네이밍)

  • 라벨 작성 시 대문자가 포함된 이름이 있는 경우 문자의 경우 소문자로 변경하고 가로 막대를 사용하여 정의된 대로 앞과 뒤의 두 부분을 연결해야 합니다. 컴포넌트 이름은 myComponent이며 레이블로 작성할 경우 my-로 작성해야 합니다. component>;
  • 정의할 때 크로스바 방식을 사용하여 구성요소 이름을 지정할 수도 있습니다.
  • 정의할 때 myComponent를 사용하는 경우 레이블은 my -comComponent>이어야 합니다. 시스템이 자동으로 인식합니다.
// 自定义的全局组件my-component// template中只有一个根元素p标签,里面包含一个button按钮Vue.component('my-component',{
    template:`<p>
        我的名字是:{{name}}
        <button>btn</button>
        </p>`,
    data(){
        return {
            name:'ccy'
        }
    },
    methods:{
        changeName:function(){
            this.name = '安之'
        }
    }})// vue对象1new Vue({
    el:"#vue-app-one",})// vue对象2new Vue({
    el:"#vue-app-two",})
로그인 후 복사

컴포넌트 사용:

① vue 객체에 해당하는 루트 요소 아래에서

를 사용합니다(el은 태그를 지정합니다). ② 정의된 전역 컴포넌트이므로 모든 vue 객체에서 사용할 수 있습니다.
③ 컴포넌트는 재사용 가능하며 vue 객체에서 여러 번 사용할 수 있으며 구성 요소는 서로 독립적입니다

<p>
    <my-component></my-component>
    <my-component></my-component></p> <p>
    <my-component></my-component></p>
로그인 후 복사

Effect:
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

data는 함수입니다

vue 객체에서 데이터 속성 값

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션) 그러나 전역 구성 요소에서는 여러 vue 개체에서 동일한 데이터를 사용할 수 있습니다. 각 개체가 별도의 데이터 복사본을 유지하지 않는 경우 특정 vue 개체가 데이터의 변수, 다른 Vue 객체가 데이터를 얻을 때 영향을 받습니다.

위의 예를 사례 연구로 사용하면 구성 요소의 데이터가 객체(참조)인 경우 다른 위치는 Vue 객체 공유가 변경되지 않습니다. 동일한 이름 변수; Vue 객체 중 하나를 통해 이름 데이터를 변경하면(즉, btn 버튼 클릭) 다른 객체에서 얻은 이름도 변경됩니다(다른 버튼의 'ccy'도 '로 변경됨). Anzhi')

따라서 데이터의 독립성을 보장하기 위해, 즉

각 인스턴스는 반환된 객체의 독립적인 복사본을 유지할 수 있습니다, 데이터는 각 인스턴스에 대해 새로 생성된 복사본을 반환합니다. vue 개체는 서로 영향을 미치지 않습니다.

vscode에서 구성 요소의 데이터는 개체가 될 수 없으며 오류가 보고됩니다.

[Vue 경고]:

"데이터" 옵션 은 다음과 같아야 합니다. 컴포넌트 정의에서 인스턴스별 값을 반환하는 함수

local 컴포넌트

    local 컴포넌트는 vue 객체에 등록되어 있으며,
  • 로컬 컴포넌트를 등록한 vue 객체만이 이 로컬 컴포넌트를 사용할 수 있습니다.
예:


로컬 컴포넌트 정의:

// template仅一个根元素:ulvar msgComponent = {
	 // 数据是自身提供的 (hobbies)
    template:`
로그인 후 복사
  • {{hobby}}
`,     data(){         return {             hobbies:['看剧','看动漫','吃好吃的']         }     }}

로컬 컴포넌트 등록:

// 仅由注册过该局部组件的vue对象才能使用,此处为p#vue-app-one// 注意命名规范,components中对象的key将会被作为标签名,多个单词拼接的命名需使用横杆法// 可以写成msg-component,此处直接简化了命名为msg,new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent    }})
로그인 후 복사

html 파일에 사용:<msg></msg>

<p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
    <p>我的爱好:</p>
    <msg></msg> <!--使用局部组件-->
로그인 후 복사

효과: 빨간색 원으로 표시된 부분 상자는 렌더링된 부분입니다. 로컬 구성 요소별
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

부모 전달 값/자식 참조: prop

정적 값 전달

자식 구성 요소 생성:

var titleComponent = {
    props:["title"],
    template:`<p>{{title}}</p>`
    // 所需要的数据title由父组件提供}
로그인 후 복사

在父组件的components属性中注册子组件:

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },})
로그인 후 복사

在父组件上使用子组件:

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
	<!--使用子组件title-component,并传值"我的爱好:"给子组件-->
    <title-component></title-component>
    <msg></msg>
로그인 후 복사

效果:红框标记处就是父向子传值并展示

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

动态传值:v-bind

定义子组件:

var titleComponent = {
    props:["title"],
    template:`<p>{{title}}</p>`}
로그인 후 복사

在父组件的components属性中注册子组件:

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },
    data(){
        return {
            title:"my hobbies are ",
        }
    }})
로그인 후 복사

使用子组件,通过绑定父组件data中的变量title来实现动态传值:

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
    <!-- 动态绑定title -->
    <title-component></title-component>
    <msg></msg>
로그인 후 복사

效果:红框处就是动态绑定获取数据的展示
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)
传递数组等复杂数据时,也可以使用v-bind来动态传值,如:
需要向子级传递hobbies数组,在vue实例对象(父)中创建数据hobbies

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },
    data:{
        title:"my hobbies are ",
        hobbies:['看剧','看动漫','吃好吃的'], //需要向子组件传递的数据
    }})
로그인 후 복사

定义子组件

var msgComponent = {
    template:`
            <p>{{hobby}}</p>            `,
    props:["hobby"],
    data(){
        return {   
        }
    }}
로그인 후 복사

使用子组件

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
    <title-component></title-component>
    <!-- 动态传值:hobbies -->
    <msg></msg>
로그인 후 복사

效果:
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)
跳回“一点想法”处

子向父:事件传值$emit

        子组件不能通过prop向父组件传递数据,需要使用事件向父组件抛出一个值,告知父组件我需要实现一个功能,由父组件处理这个事件

例子:点击按钮,改变名称chinesename
(由于data变量名不支持chinese-name形式,花括号里不支持chineseName形式,所以这里我都用了小写,此处记录一下,日后学到了新知再来填坑)

先在父组件的data中定义chinesename的初始值:

new Vue({
    el:"#vue-app-one",
    data:{
         chinesename:"anzhi" // chinesename初始值
    }})
로그인 후 복사

创建子组件,并注册事件change-name(就像click事件一样,需要让系统能够辨认这是一个事件并监听,当事件被触发时,执行某项约定好的操作):

  Vue.component('blog-post', {
    props: ['chinesename'],
    template: `
      <p>
        </p><h3>{{ chinesename }}</h3>
        <button>
            修改名字
        </button>
          `
    // blog-post组件包含一个h3,显示chinesename,和一个按钮
    // 点击这个按钮,触发change-name事件,将"ruosu"作为参数传递给指定的处理函数onChangeName
  })
로그인 후 복사

在父组件中使用子组件,定义change-name的处理函数为onChangeName:

<p>
    </p><p>这里是vue-app-one</p>
	<!-- v-bind:通过prop给子组件传递chinesename的初始值 -->
	<!-- v-on:子组件通过$emit给父组件传递新的chinesename的值 -->
	<p>
	      <blog-post></blog-post>
	 </p>
로그인 후 복사

在父组件处定义事件处理函数onChangeName:

new Vue({
    el:"#vue-app-one",
    data:{
          chinesename:"anzhi"
    },
    methods:{
        onChangeName:function(value){
        	// 将chinesename换成传递过来的数据
            this.chinesename=value        }
    }})
로그인 후 복사

效果:
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

一点想法

关于父子组件的区分,在此写一点总结,还是日后学了新知识再来填坑 ┗|`O′|┛ 嗷~~

      官网中没有很明确指明两者的定义和区别,在网上搜了一圈,觉得比较多人认可并且好理解的是:

  • el指定的根元素为父组件(使用之处为父组件)
  • vue实例对象也可看做组件

      在前面这些父子传值的例子中,我们可以看到,对于局部组件,我们会在某个html根元素中注册并使用,所以此时el指定的根元素在html文件中是这个局部组件的父组件,局部组件在html使用时便是这个父组件的一份子,承担数据传输的责任
跳转到父向子动态传值案例

vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)

      再用绕口令说一波,即:title-component组件定义处与使用处,两者身份是不一样的,在定义处,它是局部组件,也是子组件,需注册才能使用;在使用处,它是根元素的包含一部分,根元素为父组件,而“它”,承担着父组件与子组件数据沟通的重任

这个总结在全局组件情况下也适用,使用该全局组件的根元素是父组件,如上面的子向父传值的案例,p#vue-app-one是父组件,作为父子组件沟通的桥梁,全局组件blog-post为子组件
跳转到子向父案例

图示:
vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)


如果是子组件又嵌套了子组件,被嵌套的组件是子子组件,以此类推

建 스캐폴딩 프로젝트를 사용하여 컴포넌트와 컴포넌트의 통과 값을 사용하세요.

CLI 스캐폴드 설치 단계는 내 기사를 읽을 수 있습니다. CLI 스캐폴딩을 사용하여 프로젝트를 생성하는 것은 간단하고 빠릅니다. 특히 페이지 내용과 데이터 전송은 .vue 파일로 작성되어야 하며 각 vue 파일은 모듈입니다.各 각 모듈(구성 요소)의 합리적인 조립을 통해 특정 기능을 완성할 수 있습니다. 구성 요소 간의 협력과 아버지와 아들 전달의 역할은 여기서 더욱 분명해집니다. 각 vue 파일은 필요에 따라 탐색 모음, 중간 콘텐츠 및 하단 부분과 같이 페이지를 여러 부분으로 나눌 수 있습니다. 각 부분의 구현은 페이지 표시 및 데이터 수집을 포함한 다양한 하위 구성 요소로 분산됩니다.

예를 들어, 맞춤형 블로그 페이지:

메인 페이지는 네비게이션 바, 중간 부분, 하단 바를 포함한 vue-app 주요 구성 요소로 구성됩니다.

  • 네비게이션 바는 다음과 같습니다. vue-header 하위 구성 요소로 완성

  • 중간 콘텐츠는 기능에 따라 구분됩니다

  • 블로그 추가: addBlob 하위 구성 요소

    블로그 표시: showBlob 하위 구성 요소
    • 블로그 수정: ModifyBlob 하위 구성 요소
    • 클릭하면 단일 블로그 콘텐츠 표시: SingleBlob 하위 구성 요소
    • 하단 정보 vue-footer로 완성된 컬럼입니다
    메인 페이지 외에 다른 하위 구성 요소와 구성 요소가 기능별로 구분되어 있습니다. 보조 메인 페이지에는

  • 구성도가 표시됩니다. 개인 블로그 부모가 자식에게 값을 전달하는 방법은 다음과 같습니다.
각 하위 기능은 서로 다른 구성 요소로 구성되어 더 큰 기능 구성 요소로 구성됩니다.

단일 블로그를 표시하고 블로그를 수정하려면 두 구성 요소 모두 블로그 ID를 얻어야 합니다. 이는 전형적인 부모-자식 가치 전달입니다

  • vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)【관련 추천: "
    vue.js tutorial
  • "】

위 내용은 vue 구성 요소를 시작하는 데 1시간(권장 컬렉션)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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