Efektivitas Strategi Ta’bir Mushawwar dalam Pembelajaran Bahasa Arab di Madrasah Ibtidaiyah
Abstract
Speaking proficiency is one of the main skills in Arabic language learning, but fourth grade students of MI TPI Keramat face difficulties in assembling mufradat and practicing active conversation, mainly due to the lack of varied learning strategies. This study aims to analyze the effectiveness of the ta'bir mushawwar strategy, which uses picture as a media to facilitate students in constructing sentences and telling stories, in improving Arabic speaking skills. With a quantitative approach and pre-experiment design, this study involved 18 students of class IV-C. Data were collected through tests, observations, and interviews, then analyzed descriptively and N-Gain test. The posttest average was 83.06 (very good category) with 88.9% completeness, and the N-Gain score was 0.6398 which showed effectiveness in the medium category. The ta'bir mushawwar strategy offers a solution in the form of a visual and hands-on learning approach that can significantly improve students' speaking skills and make learning more interesting and interactive.
Server IP : 103.175.217.176 / Your IP : 3.144.106.207 Web Server : Apache/2.4.62 (Debian) System : Linux bilfathvps 5.10.0-33-amd64 #1 SMP Debian 5.10.226-1 (2024-10-03) x86_64 User : root ( 0) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bilfatvps/html/journal.stitaf.ac.id/lib/pkp/classes/reviewForm/ |
Upload File : |
<?php /** * @file classes/reviewForm/ReviewFormResponseDAO.inc.php * * Copyright (c) 2014-2019 Simon Fraser University * Copyright (c) 2000-2019 John Willinsky * Distributed under the GNU GPL v2. For full terms see the file docs/COPYING. * * @class ReviewFormResponseDAO * @ingroup reviewForm * @see ReviewFormResponse * * @brief Operations for retrieving and modifying ReviewFormResponse objects. * */ import ('lib.pkp.classes.reviewForm.ReviewFormResponse'); class ReviewFormResponseDAO extends DAO { /** * Retrieve a review form response. * @param $reviewId int * @param $reviewFormElementId int * @return ReviewFormResponse */ function &getReviewFormResponse($reviewId, $reviewFormElementId) { $sql = 'SELECT * FROM review_form_responses WHERE review_id = ? AND review_form_element_id = ?'; $params = array($reviewId, $reviewFormElementId); $result = $this->retrieve($sql, $params); $returner = null; if ($result->RecordCount() != 0) { $returner =& $this->_returnReviewFormResponseFromRow($result->GetRowAssoc(false)); } $result->Close(); return $returner; } /** * Construct a new data object corresponding to this DAO. * @return ReviewFormResponse */ function newDataObject() { return new ReviewFormResponse(); } /** * Internal function to return a ReviewFormResponse object from a row. * @param $row array * @return ReviewFormResponse */ function &_returnReviewFormResponseFromRow($row) { $responseValue = $this->convertFromDB($row['response_value'], $row['response_type']); $reviewFormResponse = $this->newDataObject(); $reviewFormResponse->setReviewId($row['review_id']); $reviewFormResponse->setReviewFormElementId($row['review_form_element_id']); $reviewFormResponse->setValue($responseValue); $reviewFormResponse->setResponseType($row['response_type']); HookRegistry::call('ReviewFormResponseDAO::_returnReviewFormResponseFromRow', array(&$reviewFormResponse, &$row)); return $reviewFormResponse; } /** * Insert a new review form response. * @param $reviewFormResponse ReviewFormResponse */ function insertObject(&$reviewFormResponse) { $responseValue = $this->convertToDB($reviewFormResponse->getValue(), $reviewFormResponse->getResponseType()); $this->update( 'INSERT INTO review_form_responses (review_form_element_id, review_id, response_type, response_value) VALUES (?, ?, ?, ?)', array( $reviewFormResponse->getReviewFormElementId(), $reviewFormResponse->getReviewId(), $reviewFormResponse->getResponseType(), $responseValue ) ); } /** * Update an existing review form response. * @param $reviewFormResponse ReviewFormResponse */ function updateObject(&$reviewFormResponse) { $responseValue = $this->convertToDB($reviewFormResponse->getValue(), $reviewFormResponse->getResponseType()); $returner = $this->update( 'UPDATE review_form_responses SET response_type = ?, response_value = ? WHERE review_form_element_id = ? AND review_id = ?', array( $reviewFormResponse->getResponseType(), $responseValue, $reviewFormResponse->getReviewFormElementId(), $reviewFormResponse->getReviewId() ) ); return $returner; } /** * Delete a review form response. * @param $reviewFormResponse ReviewFormResponse */ function deleteObject(&$reviewFormResponse) { return $this->deleteById($reviewFormResponse->getReviewId(), $reviewFormResponse->getReviewFormElementId()); } /** * Delete a review form response by ID. * @param $reviewId int * @param $reviewFormElementId int */ function deleteById($reviewId, $reviewFormElementId) { return $this->update( 'DELETE FROM review_form_responses WHERE review_id = ? AND review_form_element_id = ?', array($reviewId, $reviewFormElementId) ); } /** * Delete review form responses by review ID * @param $reviewId int */ function deleteByReviewId($reviewId) { return $this->update( 'DELETE FROM review_form_responses WHERE review_id = ?', $reviewId ); } /** * Delete group membership by user ID * @param $reviewFormElementId int */ function deleteByReviewFormElementId($reviewFormElementId) { return $this->update( 'DELETE FROM review_form_responses WHERE review_form_element_id = ?', $reviewFormElementId ); } /** * Retrieve all review form responses for a review in an associative array. * @param $reviewId int * @return array review_form_element_id => array(review form response for this element) */ function &getReviewReviewFormResponseValues($reviewId) { $returner = array(); $result = $this->retrieveRange( 'SELECT * FROM review_form_responses WHERE review_id = ?', (int) $reviewId ); while (!$result->EOF) { $row = $result->GetRowAssoc(false); $reviewFormResponse =& $this->_returnReviewFormResponseFromRow($row); $returner[$reviewFormResponse->getReviewFormElementId()] = $reviewFormResponse->getValue(); $result->MoveNext(); } $result->Close(); return $returner; } /** * Check if a review form response for the review. * @param $reviewId int * @param $reviewFormElementId int optional * @return boolean */ function reviewFormResponseExists($reviewId, $reviewFormElementId = null) { $sql = 'SELECT COUNT(*) FROM review_form_responses WHERE review_id = ?'; $params = array($reviewId); if ($reviewFormElementId !== null) { $sql .= ' AND review_form_element_id = ?'; $params[] = $reviewFormElementId; } $result = $this->retrieve($sql, $params); $returner = isset($result->fields[0]) && $result->fields[0] > 0 ? true : false; $result->Close(); return $returner; } }
Youez - 2016 - github.com/yon3zu
LinuXploit