谁一开始就是大神?

PHP 第65页

PHP

form表单的名字[2.0]

Tinafrog阅读(83)

我在练习权威手册上的form表单,我打完代码之后看了眼浏览器,表单的name显示的是model层的名字,1.这个是为啥呢。2.我要怎么才能设置form表单的name呀

直接在属性配置里(options)头写name就行
在from的model里面,实现attributeLabels()方法。比如

该怎么获取表单的值。[2.0]

WendyKeo阅读(84)

我先是按照手册在model层引用了Activerecord 之后view里面写了三个表单,我获取不到值啊 咋整呀 我都乱死了

Yii::$app->request->post() ( or get() )
基本的描述代码都没有啊

select2【带搜索框的select插件】如何通过change事件想select2传值?[2.0]

FionaStone阅读(85)

通过这个dropDownList中,选择的一个值,控制 下面 select 显示的列表。

$form->field($model, 'type')->dropDownList($model->get_notice_type(), [
   'prompt' => '请选择...',
    		
]);

已有的select:

$form->field($model, 'cgId')->widget(Select2::classname(), [
  'hideSearch'=>false,
  'data' => $model->get_cg_id(),
  'language' => 'zh-CN',
  'options' => ['placeholder' => '请选择...'],
  'pluginEvents' =>[
      "select2:closing" => "function() { $('#notice-cgId').blur(); }",
   ]
                    
]);

怎么通过选中一个值,控制那个select显示的列表呢?
就是这么一个忧伤的问题。
用change事件,还是啥的,都行,希望有大神能告诉我!!
实在是百度不出来。Google也用了,我也到开发这个插件的老外那留了个言【不是问的这个问题】。人家没鸟我····

假设select2对应的id=select2,且同时假设change事件会去服务端请求新的下拉数据。
那么则有
change请求到新的数据后,可拼接为一组option,然后直接把该组option填充到id=select2内即可
$('#select2').html(change事件获取到的数据拼接的option字符串);
js动态调整咯,你去搜索下三级联动.这类例子应该不少.

Yii列表页怎么更改查询的结果?[2.0]

EllieFox阅读(83)

比如查询城市表,里面有数据 广东 、广州 、深圳 、湖南 、长沙。。。为了区分省和市,省的f_id = 0,而市的呢 就是对应省的 id, 这时候我用CRUD自动生成的VIEWS, 他查询出的所属省份是直接查询出数字来的,我需要换成对应的省份。不管是更改SQL语句也好,还是直接在查询出的结果里面循环再次查询也好,都可以,我只想知道,怎么或者说,在哪更改 列表页的查询语句,还有查询结果如果我要进行处理的话,结果是在哪里出来的?小白求教,很多问题。。。先问一个。感激不尽!谢谢!

index.php视图中定义展示字段修改一下
模型中添加一个新的方法:
上面的代码可以实现展示效果,如果需要搜索,需要修改search模型。
最好的解决方法,数据表多加一个 f_name 字段, 多加一个冗余字段,程序省去了很多繁琐的处理。
你的描述我没有明白,能结合代码再描述清楚些吗

在搜索栏输入数据得到搜索结果后,我的JS就不工作了[2.0]

littleyak阅读(91)

在 GridView的每行增加操作按钮,自己写了JS,页面打开的时候JS工作正常,
然后在搜索栏输入数据得到搜索结果后,我的JS就不工作了,嘛个原因
代码大概如下:

 Pjax::begin();
    echo GridView::widget([
.......
]);
 Pjax::end();
<?php $this->beginBlock('myjs') ?>
.........
<?php $this->endBlock() ?>
<?php $this->registerJs($this->blocks['myjs'], \yii\web\View::POS_READY); ?>

打开firebug调试啊 你放一段php代码 却让大家找js错误 这思路就不对

YII2.0覆写数据表名[yii\db\ActiveRecord::tableName()][2.0]

Neoelephant阅读(88)

刚研究了一会权威手册 看到了覆写数据库表名的方法 想试试,结果试了好久都失败,就是报错,请问数据库表名覆写该修改哪里。求指教。yii\db\ActiveRecord::tableName()

代码在那里。。。。。。。。

composer无法连接[2.0]

Jimcrab阅读(87)

composer一直无法连接

请问要怎么办?

直接github.com下载 解压到vendor下行不行?

行的,有些项目,比如国内的,就有提供整个vendor目录下载.
网络不通,两个方案,挂vpn或者换composer源. 国内有人做了镜像,上次使用不知道是配置不对还是别的原因,效果不理想.日本也有一个镜像站.
有时候 下载国外的需要

php/redis更新缓存的问题[2.0]

Lislim阅读(179)

if(!$redis->exists('cache')) 
{
    echo '写入缓存<br>';
    $sql = "select * from user limit 0,3";
    $rs = mysqli_query($connect,$sql) or die('db conn error');
    while( $result = mysqli_fetch_assoc($rs) )
    {
         array_push($results,$result);
    }

    $cache = json_encode($results);
    echo $cache;
    $redis->set('cache',$cache,1200);
}
else
{
    echo '读取缓存<br>';
    echo $redis->get('cache');
}

问题:
如果我在后台修改了user某个id的name值,或者添加、删除了 如何去实时更新缓存?

是不是应该在后台update/delete操作里面去更新缓存?

比方我有一百条数据 是不是就因为update了一下某个值,就去做一次更新缓存.这样是不是不好.

通常都是这样做的。当然你也可以用缓存依赖来实现,不用自己维护缓存更新。

在插入数据库之前处理字段?[2.0]

lionslim阅读(89)

$model = new Admin();
if ($model->load(\Yii::$app->request->post()) && $model->save()) {
    return $this->redirect(['index']);
} else {
}

$model->save() 之前我要对字段进行加密处理,听说有个beforesave方法,死活找不到在哪,怎么用? 求教

你可以看下 BaseActiveRecord
862891 行有示例用法
有的啊。。。
在其对应的model类里面添加一个beforeSave()方法 ,具体怎么实现二楼已经贴出了代码
。。。。。。
$model->validate() //这个是验证数据
验证数据以后 也就是数据通过规则验证了 此时我们在修改对象Model的属性
然后在 $model->save(false) 因为是自己修改的,就不需要再次验证了。直接保存即可,。

登录

找回密码

注册