[英]Call JavaScript Function from Yii2 Form Field
我正在嘗試創建一個JS函數以在Yii2中實時計算文本區域字符。 在普通的HTML中,以下代碼可以正常工作:
<textarea id="text" onkeyup="count();" placeholder="Enter Some Text"></textarea>
但是,將此代碼映射到Yii2表單元素給我一個問題。 這是我嘗試過的,未檢測到功能count():
<?= $form->field($model, 'message')->textarea(['placeholder' => '1 message = 160 characters','rows' => 6, 'onkeyup' => 'count();']) ?>
我有什么事做錯了嗎? 以下是我的完整表單代碼:
<?php
use yii\helpers\Html;
use kartik\widgets\ActiveForm;
use kartik\builder\Form;
use kartik\datecontrol\DateControl;
/**
* @var yii\web\View $this
* @var app\models\Messages $model
* @var yii\widgets\ActiveForm $form
*/
/* start getting the totalamount */
$script = <<<EOD
function count()
{
var total = document.getElementById("messages-message").value;
total = total.replace(/\s/g, '');
document.getElementById("total").innerHTML="Total Characters:"+total.length;
}
EOD;
$this->registerJs($script);
?>
<div class="messages-form">
<?php
$form = ActiveForm::begin([
'id' => 'messages-form-vertical',
'type' => ActiveForm::TYPE_VERTICAL
]);
?>
<?= $form->field($model, 'type')->textInput(['placeholder' => 'Enter Type...']) ?>
<?= $form->field($model, 'senderID')->textInput(['placeholder' => 'Enter Sender ID...', 'maxlength' => 15]) ?>
<?= $form->field($model, 'recepient_mobile')->textInput(['placeholder' => 'Enter Recepient Mobile...', 'maxlength' => 15]) ?>
<?= $form->field($model, 'characters')->textInput(['placeholder' => 'Enter Characters...']) ?>
<?= $form->field($model, 'status')->textInput(['placeholder' => 'Enter Status...', 'maxlength' => 50]) ?>
<?= $form->field($model, 'sms_count')->textInput() ?>
<?= $form->field($model, 'message')->textarea(['placeholder' => '1 message = 160 characters','rows' => 6, 'onkeyup' => 'count();']) ?>
<p id="total">Total Characters:0</p>
<div class="form-group">
<?php echo Html::submitButton($model->isNewRecord ? Yii::t('app', 'Create') : Yii::t('app', 'Update'),
['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']
); ?>
</div>
<?php ActiveForm::end(); ?>
</div>
謝謝您的幫助。
您應該使用:
$this->registerJs($script, View::POS_HEAD);
默認情況下, registerJs()
使用POS_READY
作為$position
。 這意味着JavaScript將包含在jQuery(document).ready()
,因此定義的函數在全局上下文中不可用。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.