Unit 4 - Practice Quiz

INT252

1 Which HTML element is primarily used to collect user input in a React application?

A. <data>
B. <form>
C. <input>
D. <section>

2 In React, what is the standard event handler used to listen for changes in an input field?

A. onInput
B. onChange
C. onUpdate
D. onModify

3 What defines a 'Controlled Component' in React?

A. A component where the DOM handles the form data
B. A component accessed via refs
C. A component where React state acts as the single source of truth
D. A component that controls other child components

4 Which attribute must be set on an input element to make it a Controlled Component?

A. defaultValue
B. ref
C. value
D. name

5 If you provide a value prop to an input without an onChange handler, what is the result?

A. The input becomes read-only
B. The input works normally
C. React throws a compile error
D. The input allows typing but does not update state

6 How do you access the value entered by the user in an onChange event handler?

A. event.value
B. event.target.value
C. event.input.value
D. event.data

7 What is an 'Uncontrolled Component' in React?

A. A component managed entirely by Redux
B. A component where form data is handled by the DOM itself
C. A component without any props
D. A component that causes infinite loops

8 Which React Hook is commonly used to access the DOM node in an uncontrolled component?

A. useState
B. useEffect
C. useRef
D. useContext

9 Which attribute is used to set the initial value of an uncontrolled input component?

A. value
B. initValue
C. startValue
D. defaultValue

10 Which method is called to prevent the default page reload behavior during form submission?

A. event.stopPropagation()
B. event.preventDefault()
C. event.halt()
D. event.stopImmediatePropagation()

11 Where should the onSubmit event handler be attached?

A. The <button> element inside the form
B. The <form> element
C. The <input> element
D. The <div> wrapping the form

12 How does React handle the <textarea> element differently than HTML?

A. It uses a value attribute instead of defining text as children
B. It requires a closing tag in HTML but not in React
C. It cannot be controlled in React
D. It uses innerText instead of value

13 In a controlled <select> component, where is the selected value defined?

A. On the <option> element using the selected attribute
B. On the <select> element using the value attribute
C. On the <form> element
D. It is automatically detected

14 Which syntax is useful for handling multiple inputs with a single onChange handler?

A. Computed property names: [e.target.name]
B. Nested if-else statements
C. Multiple refs
D. Switch statements only

15 When using a checkbox input in React, which property of event.target should be used to get the value?

A. value
B. checked
C. selected
D. enabled

16 Which input type is always an uncontrolled component in React?

A. text
B. checkbox
C. file
D. password

17 What is the purpose of the htmlFor attribute in React?

A. To replace the HTML for attribute on labels
B. To link a form to a database
C. To specify the form method
D. To style the form

18 Ideally, where should validation logic reside in a Controlled Component approach?

A. Inside the render method
B. Inside the DOM
C. Inside the event handlers (onChange/onSubmit) updating the state
D. In an external CSS file

19 How can you conditionally display an error message only if an error exists?

A. {error && <p>{error}</p>}
B. {error || <p>{error}</p>}
C. <p if={error}>{error}</p>
D. display: error

20 What represents the state of a form element that has been clicked on or focused and then blurred?

A. Dirty
B. Touched
C. Clean
D. Pressed

21 Which event is best used to validate a field specifically when the user leaves that field?

A. onFocus
B. onBlur
C. onMouseEnter
D. onClick

22 Why might you choose an uncontrolled component over a controlled one?

A. For better performance with extremely large forms
B. To make the code more 'React-like'
C. To use Redux state
D. To ensure strict validation

23 How do you handle a select element with the multiple attribute in React?

A. Pass an array to the value attribute
B. Use multiple value attributes
C. It is not supported
D. Use a comma-separated string

24 What is the correct way to reset a Controlled form after submission?

A. Call form.reset()
B. Reload the page
C. Update the state variables to their initial empty values
D. Delete the input elements

25 If you need to validate an email address, which JavaScript feature is commonly used inside the validation function?

A. Regular Expressions (Regex)
B. JSON.parse()
C. Array.map()
D. Math.random()

26 What happens if you change a controlled input from undefined value to a defined value during the component lifecycle?

A. React logs a warning about switching from uncontrolled to controlled
B. The component unmounts
C. The input becomes disabled
D. Nothing happens

27 In a controlled component, the source of truth is:

A. The HTML DOM
B. The React Component State
C. The Browser's Cache
D. The Server

28 To disable a submit button when a form is invalid, which attribute should be used?

A. hidden
B. stopped
C. disabled
D. invalid

29 Which of the following is NOT a valid type for an <input> element?

A. text
B. email
C. dropdown
D. number

30 When using useRef to access a form value, how do you access the actual DOM node?

A. ref.node
B. ref.current
C. ref.value
D. ref.dom

31 What is a common library used in React for managing complex forms and validation?

A. React Router
B. Formik
C. Axios
D. Redux

32 In a radio button group, how does React know which buttons belong together?

A. They share the same id
B. They share the same name attribute
C. They are in the same div
D. They share the same value

33 What is the standard way to prevent a user from typing in an input field conditionally?

A. Use the readOnly or disabled attribute
B. Use CSS display: none
C. Remove the onChange handler
D. Use event.stop()

34 If a form validation function is asynchronous (e.g., checking username availability), where is the best place to trigger it?

A. Inside the render method
B. In the onChange handler or useEffect
C. In the CSS
D. In the index.html file

35 When using the onChange handler for a text input, what data type is event.target.value typically?

A. Number
B. String
C. Boolean
D. Object

36 What does the aria-label attribute do in a form?

A. It validates the form
B. It provides a label for screen readers for accessibility
C. It sets the input value
D. It changes the font style

37 Which approach is generally recommended by the React team for most forms?

A. Uncontrolled Components
B. Controlled Components
C. Direct DOM manipulation
D. Using jQuery

38 How can you optimize a form that lags due to validation running on every keystroke?

A. Remove validation
B. Use Debouncing on the onChange handler
C. Switch to Class components
D. Use forceUpdate

39 What is the equivalent of the HTML autofocus attribute in React?

A. autoFocus (camelCase)
B. focus=true
C. has-focus
D. It is not supported

40 If you have a form with 20 inputs, what is the downside of using separate useState hooks for each?

A. It is slower to write
B. Code becomes verbose and harder to manage
C. React limits hooks to 10
D. It causes memory leaks

41 What attribute allows an input to accept multiple files?

A. files
B. multiple
C. array
D. collection

42 In an uncontrolled form, how can you reset the form fields natively?

A. event.target.reset()
B. window.reload()
C. ref.current.reset()
D. This is not possible

43 Which React concept allows passing a ref from a parent to a child's input element?

A. Ref forwarding
B. Prop drilling
C. Context API
D. Higher Order Components

44 What is the primary role of a 'Submit Handler'?

A. To styling the button
B. To process data (e.g., send to API) and manage UI state
C. To clear the browser cache
D. To create new DOM elements

45 When validating, what does a 'Required' check ensure?

A. The input is a number
B. The input field is not empty
C. The input matches a regex
D. The input is unique

46 Can a div element typically fire an onChange event?

A. Yes, always
B. No, only form input elements fire onChange
C. Yes, if contentEditable is true
D. Yes, if it has an ID

47 How do you capture the file object from a file input onChange event?

A. event.target.value
B. event.target.files[0]
C. event.file
D. event.data.files

48 Which of the following is true regarding validation feedback?

A. It should only happen after the page reloads
B. It should be immediate and clear to the user
C. It should be hidden in the console
D. It is not necessary

49 What is the purpose of the placeholder attribute?

A. To set the default value
B. To provide a hint to the user about what to type
C. To validate the input
D. To name the input

50 If a controlled input's state is set to null, what happens?

A. It clears the input
B. It becomes uncontrolled
C. It throws an error
D. It displays the text 'null'