Coder Social home page Coder Social logo

project-survey's Introduction

Survey form with React

Site built with the aim to make a survey in React with components, props, and state, with accessibility in mind. I was inspired by the WWF climate calculator

The problem

The site is built in React with the header, the survey, the progress bar, and every input type as its own component. I first put the state hooks within each input component but was made aware of the problems with this when wanting to use those states so show the results of the survey. Now all state hooks are declared in the survey component which makes them easy to reach within that component and its children.

I used conditional rendering to only display one question at a time and to hide the form and show the result when the submit button is clicked. Validation of the form stopped working when setting the current question to hide when clicked on the next button. This was solved by setting an if statement in the onClick function that handles the next button, to only show the next question if the current input field had a value of more than an empty string.

If had more time I would add more custom styling of radio buttons and add more input types and questions to make a more usable survey.

View it live

View it live here: https://climate-react-survey.netlify.app/

project-survey's People

Contributors

corneliaryas avatar emolsz avatar dependabot[bot] avatar idlefingers avatar jenniedalgren avatar puj avatar

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.