Giter VIP home page Giter VIP logo

Comments (4)

rwu823 avatar rwu823 commented on April 27, 2024 1

I see. It works great. Thanks so much.

from babel-plugin-transform-vue-jsx.

yyx990803 avatar yyx990803 commented on April 27, 2024

Hmm, I guess this makes it technically a breaking change...

However, I think you can preserve the same component interface simply by changing the internal implementation. Instead of expecting a prop and calling it, emit an event instead:

// before
this.onChange && this.onChange(e)

// after
this.$emit('change', e)

The consumer of the component don't have to change anything. Would this work in your case?

from babel-plugin-transform-vue-jsx.

rwu823 avatar rwu823 commented on April 27, 2024

Sure, this.$emit works, but it has a problem the parent component needs to assign a ref name in each <Select /> every time. That's inconvenient.

mounted() {
  this.$refs.select1.$on('change', ...)
  this.$refs.select2.$on('change', ...)
},
render(h) {
  return (
    <div>
      <Select ref="select1" />
      <Select ref="select2" />
    </div>
  )  
}

from babel-plugin-transform-vue-jsx.

yyx990803 avatar yyx990803 commented on April 27, 2024

No, the parent can keep the exact same usage:

<Select onChange={()=>{ ... }}/>

Because onChange is now registered as a component event listener and will listen to $emit('change') from the child.

from babel-plugin-transform-vue-jsx.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.