Comments (2)
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.
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:
- UI component modules to handle drawing stuff to the screen and listening for user inputs
- App state modules to handle keeping track of the state of the app (the data/information/domain model)
- 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)
- Basic Level: Completed HOT 1
- Challenge completed level: basic
- Challenge completed level: basic HOT 1
- mid level HOT 2
- Rejection App
- Challenge completed level: basic HOT 1
- Challenge completed: Basic HOT 1
- Challenge completed level: basic HOT 1
- Challenge completed level: Mid HOT 1
- Challenge Completed: Basic Level HOT 4
- Mid level completed.
- Challenge completed level: basic HOT 1
- Challenge completed level: basic
- Challenge completed level: save/load state saga
- Challange completed: expert level
- Challenge completed: Basic level HOT 1
- Mid Level Challenge Completed HOT 2
- Challenge completed: basic level HOT 1
- Basic Level completed! HOT 6
- Mid Level Completed! HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
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.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from rejection.