效果图:

控制器:

<?php
namespace backend\controllers;
use Yii;
use yii\web\Controller;
use backend\models\Zhan;

class IndexController extends Controller
{
   //显示页面
   public function actionIndex()
   {
        $index=new Zhan();
        //接受值
         if($_POST)
         {
            $a=Yii::$app->db;
            //判断是否有删除ids
            if(Yii::$app->request->post('ids'))
            {
               $ids=Yii::$app->request->post('ids');
               $str='';
               for($i=0;$i<count($ids);$i++)
               {
                  if($a->createCommand()->delete('zhan',['id'=>$ids[$i]])->execute())
                  {
                     $str++;
                  }
               }
               if($str!='')
               {
                   echo '<script>alert("删除成功");location.href="index.php?r=index/index"</script>';
               }
            }
            else
            {    
                  //判断是否有id传值
                  $cid=Yii::$app->request->post('cid');
                  $xu_ids=Yii::$app->request->post('xu_id');
                
                  //print_r($id);die;
                  //添加行的数据
                  $names=Yii::$app->request->post('zhan_name');
                  $ulrs=Yii::$app->request->post('url');
                  //遍历数组
                  foreach($names as $k=>$v)
                  {
                     if(!empty($cid[$k]))
                     {
                        $c_id=$cid[$k];
                        //echo $c_id;die;
                        $url=$ulrs[$k];
                        $xu_id=$xu_ids[$k];
                        $name=$v;
                        $res=$a->createCommand()->update("zhan",['zhan_name'=>$name,'url'=>$url,'xu_id'=>$xu_id],"id=$c_id")->execute();
                        //数据可能没被修改,只有成功一条就改变标记的值
                        if($res)
                        {
                          echo '<script>alert("修改成功");location.href="index.php?r=index/index"</script>';
                        }  
                     }
                     else
                     {
                        $url=$ulrs[$k];
                        $xu_id=$xu_ids[$k];
                        $name=$v;
                        $res=$a->createCommand()->insert("zhan",['xu_id'=>$xu_id,'zhan_name'=>$name,'url'=>$url])->execute();
                        //数据可能没被修改,只有成功一条就改变v标记的值
                        if($res)
                        {
                           echo '<script>alert("添加成功");location.href="index.php?r=index/index"</script>';
                        }      
                     }
                 }
            }
         }
         else
         {
             //查询数据
            $models=Zhan::find()->orderBy(['xu_id'=>'asc'])->asArray()->all();
            //var_dump($models);
            return $this->renderPartial("show",['models'=>$models]);
         }
   }
}
?>

视图层:

<center>
        <form action="index.php?r=index/index" method="post">
        <input name="_csrf" type="hidden" id="_csrf" value="<?= Yii::$app->request->csrfToken ?>">
        <table>
        <tr>    
        <td>ID</td>
           <td>显示顺序</td>
           <td>站点名称</td>
           <td>站点URL</td>
        </tr>

<?php  foreach ($models as $key => $v) {?>   
        <tr>
        <input type="hidden" name="cid[]" value="<?php echo $v['id']; ?>" />
        <td><input type="checkbox" name="ids[]" class='ids' value="<?= $v['id'] ?>"></td>
        <td><input type="text" name="xu_id[]" value="<?= $v['xu_id'];?>"></td>
        <td><input type="text" name ='zhan_name[]'value="<?= $v['zhan_name'];?>"></td>
        <td><input type="text" name="url[]" value="<?= $v['url'];?>"></td>
        </tr>    
       <?php }?>

<tr>
          <td><a href="javascript:void(0)" onclick="add(this);">+添加友情链接</a></td>
          <td><input type="checkbox" onclick="jian(this);">删除?</td>
        </tr>
         <tr>
           <td><input type="submit" value="提交" ></td>
         </tr>
                    
      </table>
      </form>
</center>

<script src="style/jquery.js"></script>
<script>
//添加一行
function add(ts)
{
   var tr=$(ts).parent().parent();
   var newtr='<tr><td></td><td><input type="text" name="xu_id[]"></td><td><input type="text" name="zhan_name[]"></td><td><input type="text" name="url[]"></td><td><input type="button" value="删除该行" onclick="del(this);"></td></td></tr><br />';
   tr.after(newtr);
}
//删除当前行
function del(ts)
{   
   $(ts).parent().parent().remove();
}
//删除所有
function jian(ts)
{
   var ids=$('.ids');
   //alert(ids.length);
   for(var i=0;i<ids.length;i++)
   {
       if(ts.checked==true)
       {
         ids[i].checked=true;
       }
       else
       {
         ids[i].checked=false;
       }
   }
}
</script>
</head>

yii添加行的增删改查的更多相关文章

  1. Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]

    在Yii的开发中常常需要去使用Yii的增删改查方法,这些方法又可以多次变化和组合,带来全方位的实现对数据库的处理,下面对这些方法做一些简单的整理和梳理,有遗漏或是BUG,敬请指出.灰常感谢!!! 一. ...

  2. yii框架的增删改查

    一.新增 使用model::save()操作进行新增数据 $user= new User; $user->username =$username; $user->password =$pa ...

  3. yii使用createCommand()增删改查

    查询单条数据$sql = "SELECT `name` FROM `table` WHERE id='7'";$users=Yii::$app->db->createC ...

  4. YII 1.0 增删改查

    查询 查询多条返回数据集合 //1.该方法是根据一个条件查询一个集合 $admin=Admin::model()->findAll($condition,$params); $admin=Adm ...

  5. YII进行数据增删改查分析

    关于模型部分參考http://blog.csdn.net/buyingfei8888/article/details/40208729 控制器部分: <?php class GoodsContr ...

  6. Yii框架的增删改查总结分析

    一.查询数据 1.findAll(根据一个条件查询一个集合) $admin=Admin::model()->findAll($condition,$params); $admin=Admin:: ...

  7. Yii 1.1.17 四、属性标签、AR类增删改查、使用上传类与扩展第三方类库

    一.属性标签与规则设置 当进入网站页面,将会读数据库返回信息到视图上.那么,现在定义模型中的属性在视图标签上的显示, 也就是模型属性到前台标签的映射 // 定义模型属性到前台标签的映射 public ...

  8. yii2 增删改查

    自己总结的yii2 advanced 版本的简单的增删改查,希望对大家有所帮助 1.gii生成的actionCreate()方法中 获取插入语句的id $id = $model->attribu ...

  9. YII2生成增删改查

    下载完成后在basic/db.php配置数据库参数. 1.配置虚拟主机后进入YII入口文件 index.php 进行get传值 ?r=gii ,进入创建界面 2.点击 Model Generator下 ...

随机推荐

  1. Qt 无边框窗体改变大小 完美实现(全部自己实现)

    近期,做项目用到无边框窗体,令人蛋疼的是无边框窗体大小的改变要像右边框那样,上下左右四周,而且要流畅. 网上也找了些代码,发现居然还要连接到windows事件,这显然不合常理,后来自己新建了demo, ...

  2. java对象中继承和变量初始化顺序浅析

    先上例子代码 public class F { int age = 5; public F() { print(); } public void print() { System.out.printl ...

  3. QGridLayout--01

    #include "mainwindow.h" #include <QApplication> #include<QLabel> #include<Q ...

  4. Top Five Communication Skills for Project Managers

    Research among project managers globally identifies top communication skills for leading teams. Lead ...

  5. sql server 数据库还原

    1. 用sa身份或Windows Authentication登陆数据库 2.鼠标右击DataBases选New Database 3.填写DataBase name,选择Database files ...

  6. Docker 介绍以及其相关术语、底层原理和技术

    https://ruby-china.org/topics/22004 Docker是啥 Docker是一个程序运行.测试.交付的开放平台,Docker被设计为能够使你快速地交付应用.在Docker中 ...

  7. Docker镜像的创建、存出、载入

    创建镜像的方法有三种:基于已有镜像的容器创建.基于本地模板导入.基于Dockerfile创建,本博文讲解前两种. 基于已有镜像的容器创建 该方法是使用docker commit命令,其命令格式为:   ...

  8. Linux下获取公网IP地址

    curl http://members.3322.org/dyndns/getipcurl http://ip.6655.com/ip.aspx

  9. linux 文件权限 初级

    sudo lsattr /etc/sudoers  查看属性 sudo vi index.html 以root权限编辑文件

  10. Power-BI For K3 免费版培训与交流!Q群视频培训,绝对干货!

    Power-BI  For K3 免费版培训与交流!Q群视频培训,绝对干货!1.产品安装与配置:2.产品使用:3.个性化开发(现场提需求现场开发):4.交流互动.时间:2015-12-03(周四)晚8 ...