Giter Site home page Giter Site logo

Comments (6)

wraithgar avatar wraithgar commented on May 26, 2024

In cases like this we've tended towards a more helpful exception. If you query against a nonexistent el it should still probably throw, but it should throw a specific error like 'this.el not defined'

ETA: This is just my opinion, adding discussion label.

from ampersand-view.

kamilogorek avatar kamilogorek commented on May 26, 2024

Agree with @wraithgar Querying is only possible on rendered elements or something similar.

from ampersand-view.

wraithgar avatar wraithgar commented on May 26, 2024

Just to be clear, the current options are: add the guard to query that already exists in queryAll, or make both throw a descriptive exception if this.el is not defined

from ampersand-view.

nirrek avatar nirrek commented on May 26, 2024

I think having a useful exception thrown is preferable to simply returning an empty array or undefined.

Empty array / undefined should mean that DOM traversal was correctly performed, but there were no matches found.

When el is undefined, you never actually perform a search at all. This will never be the intention of the user, so they should be notified that they are doing something incorrectly.

Possible exception message:
Query cannot be performed as this.el is not defined. Ensure that the view has been rendered.

from ampersand-view.

wraithgar avatar wraithgar commented on May 26, 2024

I like that. This would still be a breaking change as anyone currently relying on the guard statement would now be getting an exception thrown.

from ampersand-view.

pgilad avatar pgilad commented on May 26, 2024

^ Added a PR for this. I agree error should be thrown as to be verbose.
Notice:

  1. Change queryAll to first throw if this.el doesn't exist, then possibly return [this.el] if !selector.
  2. Breaking change for queryAll
  3. Test?

from ampersand-view.

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.