Giter Site home page Giter Site logo

Basic Challenge Completed about rejection HOT 2 CLOSED

thoragio avatar thoragio commented on September 17, 2024
Basic Challenge Completed

from rejection.

Comments (2)

thoragio avatar thoragio commented on September 17, 2024 1

Thanks for the feedback, Eric. Much appreciated.

I will try refactoring the app by putting the functions into different modules as you suggest. Once I have done that, I will add in the functionality for the mid-level of the project.

Your point on frameworks/React are noted. I am headed in that direction already. Thanks again.

from rejection.

ericelliott avatar ericelliott commented on September 17, 2024

Nice work!

I like the UI you came up with. It's quite intuitive.

It looks to me like the reason for the TDD struggle is that there isn't really much in the way of separation of concerns. I do most of my TDD using unit tests, which are designed to test individual units -- little pieces of the app. For that to work, you need to break the code up into modules. Typically:

  1. UI component modules to handle drawing stuff to the screen and listening for user inputs
  2. App state modules to handle keeping track of the state of the app (the data/information/domain model)
  3. Modules to handle things like communicating over the network, saving/loading data, etc...

When you separate your app in those ways, it becomes a lot more clear how to test things. Frameworks often help us answer the question of how to separate apps into those various pieces. There are an infinite number of ways you could separate an app (many of them valid). What frameworks do is draw the lines for us so we just need to fill in the details for our particular application.

It will take some time to learn a framework (I recommend that you start with React). Before you dig too deeply into that, try separating different functions from your app into different modules, and use import or require() to pull them together.

That will require you to use a build step. That can be complicated to set up, but you can skip most of the configuration if you try out Next.js, because it handles most of that for you.

from rejection.

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.