thinkphp5控制器向+vue的data里传值

Posted HaimaBlog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了thinkphp5控制器向+vue的data里传值相关的知识,希望对你有一定的参考价值。

传一维数组传值

$array=[‘id‘=>40,"cat_name"=>"明星产品"];
$MenuCats_info=json_encode($array,JSON_UNESCAPED_UNICODE);
$this->assign([
    ‘MenuCats_info‘=>$MenuCats_info,
]);
return view(‘index‘);

html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>vue</title>
    <link rel="stylesheet" href="">
    <!--<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
    <script type="text/javascript" src="__STATIC__/vue/vue.js"></script>
    <script type="text/javascript" src="__STATIC__/vue/node_modules/axios/dist/axios.js"></script>
    <style type="text/css">
        .success{
            color:green;
        }
        .error{
            color:red;
        }
    </style>
</head>
<body>
<div id="vue">
    <li v-for="v in news">
        <span :class="v.status?‘success‘:‘error‘">{{v.title}}</span>
        <button v-on:click="changeStatus(v,false)" v-if="v.status">删除</button>
        <button v-on:click="changeStatus(v,true)" v-if="!v.status">恢复</button>
    </li>
    {{MenuCats_info.cat_name}}
</div>
</body>
<script type="text/javascript">
    var app = new Vue({
        el: "#vue",

        data:{
            news:[
                {title:‘haha‘,status:true},
                {title:"hehe",status:true}
            ],
            //接收值 |raw 不转义输出
            MenuCats_info:JSON.parse(‘{$MenuCats_info|raw}‘),

        }
    });

</script>
</html>

效果:打印
明星产品


传二维数组:

php里:

$array=array(
    [‘id‘=>35,"cat_name"=>"吐司面包"],
    [‘id‘=>40,"cat_name"=>"明星产品"]
);
$MenuCats_info=json_encode($array,JSON_UNESCAPED_UNICODE);
$this->assign([
    ‘MenuCats_info‘=>$MenuCats_info,
]);
return view(‘index‘);

html里:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>vue</title>
    <link rel="stylesheet" href="">
    <!--<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>-->
    <script type="text/javascript" src="__STATIC__/vue/vue.js"></script>
    <script type="text/javascript" src="__STATIC__/vue/node_modules/axios/dist/axios.js"></script>
    <style type="text/css">
        .success{
            color:green;
        }
        .error{
            color:red;
        }
    </style>
</head>
<body>
<div id="vue">
    <li v-for="v in news">
        <span :class="v.status?‘success‘:‘error‘">{{v.title}}</span>
        <button v-on:click="changeStatus(v,false)" v-if="v.status">删除</button>
        <button v-on:click="changeStatus(v,true)" v-if="!v.status">恢复</button>
    </li>
    <div v-for="vv in MenuCats_info">
        {{vv.cat_name}}
    </div>

</div>
</body>
<script type="text/javascript">
    var app = new Vue({
        el: "#vue",

        data:{
            news:[
                {title:‘haha‘,status:true},
                {title:"hehe",status:true}
            ],
            //接收值 |raw 不转义输出
            MenuCats_info:JSON.parse(‘{$MenuCats_info|raw}‘),

        }
    });

</script>
</html>

以上是关于thinkphp5控制器向+vue的data里传值的主要内容,如果未能解决你的问题,请参考以下文章

VUE组件的封装--父组件向子组件传值 调用父组件的方法改变子组件data&调用子组件方法

Vue 第八章 子组件向父组件传值

vue父组件向子组件传的值怎么放进子组件的data里面

Vue 组件&组件之间的通信 之 子组件向父组件传值

Vue父组件向子组件传值 (props)、子组件改变父组件的值($emit)

vueprovide传值对象不能取data的值