效果图:

控制器:

<?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. FastReport的交叉表实际使用的一个例子

    计算发行-->定义份数月表(打开)出现 PosFraisPaysInput选择时间段后,点击“打印”.这个设计表格,就是交叉表. 交叉表的特点是:数据库是一条一条并列的但是出来的结果却是:横向是 ...

  2. php--sphinx的使用

    sphinx安装,配置,使用,分页 Sphinx简介 SQL   结构化查询语言(是一种标准,所有的关系型数据库Mysql,sqlserver,oracle) sphinx的使用两种方式: 第一种: ...

  3. MongoDB的find用法

    0.查询符合条件数据的总条数 如:db.list名.find({条件}).count(); 1.返回指定的键值:db.list.find({条件},{name:"任意值",age: ...

  4. C/C++ 笔试、面试题目大汇总

    1.求下面函数的返回值( 微软) int func(x) { int countx =0; while(x) { countx ++; x = x&(x-1); } return countx ...

  5. ligerui多选动态下拉框

    今天下午要求做一个支持多选的,并且插件用ligerui的,当时有点小懵了,因为没用过ligerui啊!而且按照API的介绍,我做得也很好啊,可是为什么就是显示不出来?据说有位小神比较厉害,请教来之,两 ...

  6. 根据IP查主机名和MAC地址

    根据IP查主机名: nbtstat -a XXX.XXX.XXX.XXX根据IP查MAC地址: arp -a XXX.XXX.XXX.XXXXXX.XXX.XXX.XXX指代要查的主机的IP

  7. Block作为property属性实现页面之间传值(代替Delegate代理与协议结合的方法)

    需求:在ViewController中,点击Button,push到下一个页面NextViewController,在NextViewController的输入框TextField中输入一串字符,返回 ...

  8. JS位操作符

    1.按位与 AND & var result = 25 & 3; alert(result); //1var result2 = 25 & -3;alert(result2); ...

  9. LeetCode Binary Search Tree Iterator

    原题链接在这里:https://leetcode.com/problems/binary-search-tree-iterator/ Implement an iterator over a bina ...

  10. rem适配

    //REM适配new function() { var _self = this; _self.width = 640; // 设置默认最大宽度 _self.fontSize = 100; // 默认 ...