javascript - Yii Framework formbuilder - 有没有办法改变验证javascript中的inputID?

标签 javascript validation frameworks yii formbuilder

在 Yii 中使用表单生成器时,有什么方法可以更改验证 javascript 中的 inputID 吗?

我的问题是我在一个页面上有两个相似的表单(使用一个表单生成器代码)。 这是登录表单,使用了两次。 首先,在模板中(显示在网站的每个页面上),第二个 - 在/site/login 页面中使用相同的表单(此页面用于在访问限制等情况下重定向用户)。

这两个表单工作正常,但是 yii 为两个表单的元素生成具有相同 inputID 的验证 javascript,并且我不知道如何更改它。 看看:

<script type="text/javascript">
/*<![CDATA[*/
jQuery(function($) {
jQuery('a[rel="tooltip"]').tooltip();
jQuery('a[rel="popover"]').popover();
$('#loginForm').yiiactiveform({'attributes':[{'id':'LoginForm_email','inputID':'LoginForm_email','errorID':'LoginForm_email_em_','model':'LoginForm','name':'LoginForm[email]','enableAjaxValidation':true,'inputContainer':'div.control-group'},{'id':'LoginForm_password','inputID':'LoginForm_password','errorID':'LoginForm_password_em_','model':'LoginForm','name':'LoginForm[password]','enableAjaxValidation':true,'inputContainer':'div.control-group'},{'id':'LoginForm_rememberMe','inputID':'LoginForm_rememberMe','errorID':'LoginForm_rememberMe_em_','model':'LoginForm','name':'LoginForm[rememberMe]','enableAjaxValidation':true,'inputContainer':'div.control-group'}]});
$('#quickLoginForm').yiiactiveform({'attributes':[{'id':'LoginForm_email','inputID':'LoginForm_email','errorID':'LoginForm_email_em_','model':'LoginForm','name':'LoginForm[email]','enableAjaxValidation':true,'inputContainer':'div.control-group'},{'id':'LoginForm_password','inputID':'LoginForm_password','errorID':'LoginForm_password_em_','model':'LoginForm','name':'LoginForm[password]','enableAjaxValidation':true,'inputContainer':'div.control-group'},{'id':'LoginForm_rememberMe','inputID':'LoginForm_rememberMe','errorID':'LoginForm_rememberMe_em_','model':'LoginForm','name':'LoginForm[rememberMe]','enableAjaxValidation':true,'inputContainer':'div.control-group'}]});
jQuery('#collapse_0').collapse({'parent':false,'toggle':false});
});
/*]]>*/
</script>

这就是问题所在。我不明白,如何改变这个: 'id':'LoginForm_email','inputID':'LoginForm_email', 到: 'id':'quickLoginForm_email','inputID':'quickLoginForm_email', 使验证适用于两种形式。 我尝试更改表单 id、表单标题、元素 id、元素名称 (ofc),但没有结果。 是否可以动态更改它,而不更改表单文件名等? 我尝试阅读 CActiveForm 源代码,但没有找到它在哪里获取 inputID。

Ofc 可以不在/site/login 页面上显示布局表单,但这不是我认为的最好方法。

最佳答案

所以,在阅读了 3-4 个小时的 Yii 源代码之后,让我发布我自己问题的答案。 我们要在生成的 javascript 中更改的第一件事是错误 inputID。 就像 mashingan 写的,如果你不使用表单生成器,你可以在 $form->error 中设置。 如果您使用表单生成器,则可以从 CFormInputElement 类的 errorOptions 属性访问错误选项:

    'elements'=>array(
        'email'=>array(
            'id'=>$this->id.'_email',
            'name'=>$this->id.'[email]',
            'type'=>'text',
            'maxlength'=>32,
            'label'=>false,
            'placeholder'=>'Your email address',            
            'errorOptions'=>array('inputID'=>$this->id.'_email','id'=>$this->id.'_email'),
        ),

请注意,默认情况下您无法访问此数组中的表单 ID 或其他内容。 在构造表单对象时,您必须发送 $this->id (或将其命名为您想要的任何名称)。我创建了 MyForm 类,扩展了 CForm,并带有构造函数:

class MyForm extends CForm
{
public $id;
public function __construct($config, $model = null, $parent = null, $id = null) {
    if($id != null) $this->id = $id;
    parent::__construct($config, $model, $parent);
}

然后我在布局中创建表单:

$quickLoginForm = new MyForm('application.views.site.loginForm', $model, null, 'QuickLoginForm');

$loginForm = new MyForm('application.views.site.loginForm', $model, null, 'LoginForm');

上面的示例将允许您动态更改 Yii 生成的验证 javascript 中的 inputID 和 errorID。

现在让我们看看 yii 生成的 JS:

'id':'LoginForm_email','inputID':'QuickLoginForm_email','errorID':'QuickLoginForm_email'

我们已经更改了 inputID 和 errorID,接下来我们必须更改“id”以使验证适用于两个相同的表单。

但是怎么办呢?文档中没有关于此的信息。 让我们看看 CActiveForm->error() 来源:

...
$id=CHtml::activeId($model,$attribute);
...

好的,那么 CHtml::activeId 是做什么的?

public static function activeId($model,$attribute)
{
    return self::getIdByName(self::activeName($model,$attribute));
}

...

public static function activeName($model,$attribute)
{
    $a=$attribute; // because the attribute name may be changed by resolveName
    return self::resolveName($model,$a);
} 

...

public static function resolveName($model,&$attribute)
{
...
    return get_class($model).'['.$attribute.']';
}

真是天才啊!它们采用模型名称在生成的 JavaScript 中使用。 不是表单 ID,不是元素名称,它们使用模型类名称!

我不知道,薛强抽的是什么烟,但是如果你想让验证javascript在一个页面上的两个相同的表单上工作,你必须制作两个相同的模型。

因此,如果我们想更改 javascript 中的“id”,我们必须这样做:

<?php
class QuickLoginForm extends LoginForm
{
}

(LoginForm是我们的模型)并在生成第二个表单时使用。

$quickLoginModel=new QuickLoginForm;
$quickLoginForm = new MyForm('application.views.site.loginForm', $quickLoginModel, null, 'QuickLoginForm');

恭喜! 经过两次修改后,我们的验证 javascript 可以用于两个相同的表单。 如果你不能在一个页面上制作两个登录表单而不像猴子一样在 yii javascript 生成器的源代码中跳转,我不知道如何谈论代码重用或将 Yii 命名为“可扩展框架”。

关于javascript - Yii Framework formbuilder - 有没有办法改变验证javascript中的inputID?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12735577/

相关文章:

jquery - 检查子 div 是否有类的自定义方法 - jquery validate

validation - 在 Blade 中调用 @if ($errors->has()) 时,调用数组上的成员函数 has()

java - 寻找Java嵌入式数据库框架/引擎

Java Web 应用程序框架,用于处理需要长时间计算的进程的客户端回调

frameworks - Zend Framework 2 模块

javascript - 如何使用纯JS在每个<tr>之后插入<tr>

javascript - 为什么我们要用eval弹出一个新窗口?

PHP 验证字符串字符是英国或美国键盘字符

javascript - 如何在 ExpressJS 的静态资源中使用 `GET` 和 `POST` 参数

javascript - 获取网页URL(不改变URL跳转到其他页面)