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. <form>
B. <input>
C. <data>
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. onModify
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. ref
B. name
C. value
D. defaultValue

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.input.value
B. event.target.value
C. event.value
D. event.data

7 What is an 'Uncontrolled Component' in React?

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

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

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

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

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

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 <input> element
B. The <form> element
C. The <button> element inside the form
D. The <div> wrapping the form

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

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

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

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

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

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

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

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

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

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

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

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

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. <p if={error}>{error}</p>
B. display: error
C. {error && <p>{error}</p>}
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. onMouseEnter
B. onClick
C. onFocus
D. onBlur

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

A. To make the code more 'React-like'
B. To use Redux state
C. For better performance with extremely large forms
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 a comma-separated string
C. It is not supported
D. Use multiple value attributes

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

A. Reload the page
B. Call form.reset()
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. The input becomes disabled
B. The component unmounts
C. React logs a warning about switching from uncontrolled to controlled
D. Nothing happens

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

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

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

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

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

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

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

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

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

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

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

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

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. Use the readOnly or disabled attribute
D. Remove the onChange handler

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

A. In the onChange handler or useEffect
B. Inside the render method
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. Object
B. Number
C. String
D. Boolean

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

A. It changes the font style
B. It provides a label for screen readers for accessibility
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. Controlled Components
B. Direct DOM manipulation
C. Uncontrolled Components
D. Using jQuery

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

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

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

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

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. multiple
B. files
C. collection
D. array

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

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

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

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

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

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

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

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

46 Can a div element typically fire an onChange event?

A. Yes, if contentEditable is true
B. Yes, always
C. No, only form input elements fire onChange
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.data.files
D. event.file

48 Which of the following is true regarding validation feedback?

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

49 What is the purpose of the placeholder attribute?

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

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

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