作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个 JS 函数来在 Yii2 中实时计算 textarea 字符。在普通的 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()
中,因此定义的函数在全局上下文中不可用。
关于javascript - 从 Yii2 表单字段调用 JavaScript 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53006038/
我尝试通过正则表达式将文本中的单引号更改为双引号。 (单字)示例:我走了。 You gona fly to planet 'Ziqtos' => 我需要在 I'm 中保留单引号,并在 You gona
我正在构建一个 API,其中大部分将包含 JSON 和 HTML 内容。但是一些非常具体的端点只呈现 true 或 false,并且还在 POST 中接受 true 或 false。这是请求或响应的整
我是一名优秀的程序员,十分优秀!