logo LOGO

小程序模板制作几百元到几千元

2021-07-02 05:03:04

小程序模板制作几百元到几千元

我就废话不多说了,大家还是直接看代码吧~这一次可以看出,ajdbxx和zbajxx表做了hash semi join 消除了nestedloop,cost降到了3231.97。并且使用上了i_t_zhld_ajdbxx_m6子查询中in的结果集有一万多条数据。项目招商找 快速获取精准代理名单

要做本书中介绍的示例实验,你的计算机需要拥有100MB以上的硬盘可用空间,并安装一个文本或代码编辑器(注意这不是指文字处理软件)。第1章介绍了设置PHP 7开发环境的方式。你可以自己搭建Web服务器,也可以不搭建Web服务器,因为PHP 7解释程序自带了一个在开发环境中使用的Web服务器。是否联网也不做要求,但是如果联网就可以下载代码(如PSR-7接口),以及阅读PHP 7.x的说明文档。本书面向的读者

软件架构师、技术主管、中高级软件开发者和爱好者都适合阅读本书。在阅读本书之前,你需要先具备PHP程序设计的基础知识(OOP方面的尤为重要)。本书各章标题结构

本书会反复出现“准备工作”“具体处理过程”“具体运行情况”“补充说明”和“扩展”等标题。

这些标题都用于说明完成示例实验的步骤,下面是它们的具体含义。准备工作

该标题下方是介绍示例实验的主要内容,以及该实验的初步设置和所有软件设置。具体处理过程

该标题下方是做示例实验的具体步骤。具体运行情况

该标题下方是前面具体步骤所介绍代码的详细运行情况。补充说明

该标题下方是与前面介绍的示例程序有关的补充资料,以便使你进一步了解这些示例程序。扩展

该标题下方是与前面介绍的示例程序有关的网站链接。


前端小林问我,它从前端的返回的某些字段,想知道那个表有这个字段,它想操作这个表……/*****粗加工后台数据(给单条数据增加了id,和pid,type,title),如果后台数据返回的直接带有层级结构的数据直接跳过这个步骤) * for(i=0;i<odata.length;i++){ if(odata[i].level>=2){ //data[i].frameMenuStr //截取倒数后两个"."后边的字符串/ let arr =["a","b","c","d","e","f","g","h","i"]; let str = odata[i].frameMenuStr;//当前数据ID odata[i].id= arr[odata[i].level-1]+str.substring(str.lastIndexOf(".")+1); let j =str.lastIndexOf(".");//当前数据父节点ID odata[i].pid= arr[odata[i].level-2]+str.substring(str.lastIndexOf(".",j-1),str.lastIndexOf(".")); odata[i].title = odata[i].menuName; odata[i].type = 'item'; }else{ odata[i].id = "a"+odata[i].frameMenuStr; odata[i].title = odata[i].menuName; odata[i].type = 'folder'; //odata[i].pid = "00000000"; } } * ********/ /******* * * data:灌入的数据(后台返回的值要为有id和pid) * dom 所要绑定的区域id * callbackfun:回调函数 * 范例:function bindTree(data,dom,callbackfun){ /************核心应用:数组操作******************/ let tree = data; var treeMaps = {}; tree.forEach(function (value, index) { treeMaps[value.id] = value; }) var data = []; tree.forEach(function (value, index) { var parent = treeMaps[value.pid] if (parent !== undefined) { if (parent.products === undefined) { parent.products = [] } parent.products.push(value) } else { data.push(value); } }) /***************以上这段代码是二次加工数据为的让之前没有层级结构的数据,加工成有层级结构的数据结构********************/ dom.tree({ dataSource:function(options, callback) { // 模拟异步加载 let num = 0;//通过num值操作区分(这是个坑一定要用这种方法,不能用data||options.products) if(num==0){ setTimeout(function() { callback({data: data});//初始显示最高级别数据 num++; }, 400); }else{ setTimeout(function() { callback({data: options.products});//点击节点显示的数据 }, 400); } }, multiSelect: false, cacheItems: true, folderSelect: false, }); dom.on('selected.tree.amui', function (event, data) { // do something with data: { selected: [array], target: [object] } // console.log(data); // console.log(event); uuid = data.target.menuId; resData = data.target; if(callbackfun || typeof callbackfun != 'undefined' || callbackfun != undefined){ return callbackfun(uuid); } }); dom.tree("discloseAll");//这个函数暂时不起作用。 } /**直接调用函数*/ bindTree(odata,$("#tree"),function(){console.log("-------")}); 备注: //dom.tree("destroy");//数据更新我调用这个函数。但是一旦调用,直接所有dom结构都没有了,所以你要向之前绑定数据的地方重新灌入dom结构。 /***********插件结构重新绘制***************/ // let str = ""; // str+='<li class="am-tree-branch am-hide" data-template="treebranch">'; // str+='<div class="am-tree-branch-header">'; // str+='<button class="am-tree-branch-name">'; // str+='<span class="am-tree-icon am-tree-icon-folder"></span>'; // str+='<span class="am-tree-label"></span>'; // str+='</button>'; // str+='</div>'; // str+='<ul class="am-tree-branch-children"></ul>'; // str+='<div class="am-tree-loader"><span class="am-icon-spin am-icon-spinner"></span></div>'; // str+='</li>'; // str+='<li class="am-tree-item am-hide" data-template="treeitem">'; // str+='<button class="am-tree-item-name">'; // str+='<span class="am-tree-icon am-tree-icon-item"></span>'; // str+='<span class="am-tree-label"></span>'; // str+='</button>'; // str+='</li>'; // dom.append(str);

小程序模板制作几百元到几千元