Unit 4 - Practice Quiz

INT252 50 Questions
0 Correct 0 Wrong 50 Left
0/50

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

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

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

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

3 What defines a 'Controlled Component' in React?

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

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. React throws a compile error
B. The input becomes read-only
C. The input allows typing but does not update state
D. The input works normally

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

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

7 What is an 'Uncontrolled Component' in React?

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

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

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

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

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

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

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

11 Where should the onSubmit event handler be attached?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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 CSS
C. In the index.html file
D. In the onChange handler or useEffect

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

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

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

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

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

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

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

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

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

A. has-focus
B. focus=true
C. autoFocus (camelCase)
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. React limits hooks to 10
B. It is slower to write
C. It causes memory leaks
D. Code becomes verbose and harder to manage

41 What attribute allows an input to accept multiple files?

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

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

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

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

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

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 is unique
C. The input field is not empty
D. The input matches a regex

46 Can a div element typically fire an onChange event?

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

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

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

48 Which of the following is true regarding validation feedback?

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

49 What is the purpose of the placeholder attribute?

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

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

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