<spanmicrosoft yahei><span><!</span><span>DOCTYPE html</span><span>></span> <span><</span><span>html</span><span>></span> <span><</span><span>head</span><span>></span> <span><</span><span>meta </span><span>charset</span><span>="utf-8"</span><span>></span> <span><</span><span>meta </span><span>http-equiv</span><span>="X-UA-Compatible"</span><span> content</span><span>="IE=edge,chrome=1"</span><span>></span> <span><</span><span>meta </span><span>name</span><span>="viewport"</span><span> content</span><span>="target-densitydpi=device-dpi, initial-scale=1, user-scalable=0, maximum-scale=1"</span><span>></span> <span><!--</span><span>隐藏浏览器的工具栏和菜单栏,对iso系统起用</span><span>--></span> <span><!--用于PC上调式,不参与合并压缩</span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/data/database.js"</span><span> name</span><span>="noBuild"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span>Iframe加载处理</span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/LoadMode.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/jQuery.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/underscore.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/SVGIcons/snap.min.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/pixi.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/Xut.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/isMobile.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/aaronRequire.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/nextTick.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/Config.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/lang/Object.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/lang/Function.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/lang/Array.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/video.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 自定义事件,合集处理,iframe通讯 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/core/event/asEvented.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/core/message/pms.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span>插件</span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/cordova.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/readAssetsFilePlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/initDatabase.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/web.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/video.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/openAppPlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/tabletPlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/statusbar.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/iap.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/AppStoreLink.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/downloadPlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/xxteManager.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/unzipPlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/readPlugin.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/plugin/deletePlugin.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 动画库 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/TweenMax.min.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/plugins/ThrowPropsPlugin.min.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/PptAnimation.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/CanvasAnimation.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/dragdrop/Draggable.min.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/dragdrop/dragdrop.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/iscroll.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/hammer.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/SVGIcons/svgicons-config.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/SVGIcons/svgicons.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/animate/SpriteA.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/Utils.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/LocalStorage.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/ScriptLoad.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/ExecuteSql.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/PromptNotice.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/util/edge.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 配置文件,数据文件,结构文件 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/data/Store.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/data/StoreManager.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 数据初始化 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/Main.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/Initialize.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scenario/SceneLayout.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scenario/SceneFactory.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scenario/SceneController.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/LoadScene.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/Dispatcher.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 工具栏 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/toolbar/Navbar.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/toolbar/sToolbar.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/toolbar/fToolbar.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/toolbar/searchBar.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/toolbar/bookMark.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 多线程任务片 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/threadTask/Buffer.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/threadTask/TaskContents.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/threadTask/TaskComponents.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/threadTask/TaskBackground.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/threadTask/TaskContainer.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/Parser.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/Collection.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/MultiEvent.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/PageBase.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/Page.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/pageBase/Master.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 页面管理模块 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/transform/Translation.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/OverrideApi.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/Abstract.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/Emitter.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/PageMgr.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/MasterMgr.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/Compiler.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/ViewModel.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/SwitchPage.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/controller/EventDrive.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span>热点管理</span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/AssignAutoRun.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/AssignTrigger.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/AssignSuspend.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/AssignOriginal.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/AssignRecovery.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/ProcessControl.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/scheduler/Binding.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span> 适配器,用于处理热点 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/directives/dir-Content.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/directives/dir-Widget.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/directives/dir-Media.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/directives/dir-Action.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/directives/dir-ShowNote.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span>多媒体对象 </span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/component/media/Audio.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/component/media/Video.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/component/media/AudioManager.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/component/media/VideoManager.js"</span><span>></</span><span>script</span><span>></span> <span><!--</span><span>文本热点</span><span>--></span> <span><</span><span>script </span><span>src</span><span>="lib/component/content/conFilter.js"</span><span>></</span><span>script</span><span>></span> <span><</span><span>script </span><span>src</span><span>="lib/component/content/conAlgorithm.js"</span><span>></</span><span>script</span><span>></span> <br></spanmicrosoft>
<?<span>php </span><span>header</span>("Content-type: text/html; charset=utf-8"<span>); </span><span>/*</span><span>* * 根据index.html文件中引用的js,生成compressJs.bat * @author frog <278500368@qq.com> * @date 2014-11-17 <span>*/</span> <span>interface</span><span> ICompress { </span><span>/*</span><span>* * 处理用户请求 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span><span> request(); </span><span>/*</span><span>* * 处理输出结果 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span><span> render(); } </span><span>class</span><span> BaseCompress { </span><span>public</span> <span>$content</span><span>; </span><span>public</span> <span>$outPath</span><span>; </span><span>public</span> <span>$isAuto</span><span>; </span><span>public</span> <span>function</span> __construct(<span>$isAuto</span>=<span>false</span><span>){ </span><span>$outPath</span> = '_file'<span>; </span><span>if</span>(!<span>is_dir</span>(<span>$outPath</span><span>)){ </span><span>mkdir</span>(<span>$outPath</span><span>); } </span><span>$this</span>->outPath = <span>$outPath</span><span>; </span><span>$this</span>->isAuto = <span>$isAuto</span><span>; } </span><span>/*</span><span>* * 运行批处理 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span> runBat(<span>$name</span><span>){ } } </span><span>/*</span><span>* * 压缩javascript文件 * 合并javascript文件 </span><span>*/</span> <span>class</span> CompressJS <span>extends</span> BaseCompress <span>implements</span><span> ICompress { </span><span>/*</span><span>* * 处理用户请求 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span><span> request(){ } </span><span>/*</span><span>* * 处理输出结果 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span><span> render(){} } </span><span>/*</span><span>* * 压缩样式文件 </span><span>*/</span> <span>class</span> CompressCSS <span>extends</span> BaseCompress <span>implements</span><span> ICompress { </span><span>public</span> <span>function</span><span> request(){ } </span><span>/*</span><span>* * 处理输出结果 * @return [type] [description] </span><span>*/</span> <span>public</span> <span>function</span><span> render(){} } </span><span>/*</span><span>* * 工厂类 </span><span>*/</span> <span>class</span><span> Factory { </span><span>public</span> <span>static</span> <span>function</span> create(<span>$type</span>,<span>$isAuto</span><span>){ </span><span>$ob</span> = <span>null</span><span>; </span><span>switch</span> (<span>$type</span><span>) { </span><span>case</span> 'js': <span>$ob</span> = <span>new</span> CompressJS(<span>$isAuto</span><span>); </span><span>break</span><span>; </span><span>case</span> 'css': <span>$ob</span> = <span>new</span> CompressCSS(<span>$isAuto</span><span>); </span><span>break</span><span>; </span><span>default</span>: <span>#</span><span> code...</span> <span>break</span><span>; } </span><span>return</span> <span>$ob</span><span>; } }</span>
그런 다음 통화 처리:
<span>//</span><span>处理ajax请求</span> <span>if</span>(<span>isset</span>(<span>$_POST</span>['submit'<span>])){ </span><span>//</span><span>是否自动执行批处理</span> <span>$isAuto</span> = <span>$_POST</span>['zip'] === 'true' ? <span>true</span> : <span>false</span><span>; </span><span>//</span><span>处理类型</span> <span>$type</span> = <span>$_POST</span>['type'<span>]; </span><span>$c</span> = Factory::create(<span>$type</span>,<span>$isAuto</span><span>);<br> //接口方法 </span><span>$c</span>-><span>request(); </span><span>$c</span>-><span>render(); }</span><span>else</span><span>{ </span><span>echo</span> '请使用静态页访问本程序:<a href="index.html">点此进入</a>'<span>; }</span>
거친 뼈대가 나옵니다. 구체적인 코딩 과정은 비교적 간단합니다. 조금 더 어려운 방법은 일괄 처리를 수행하는 것입니다.
이 방법은 온라인에서 제공되는 방법으로 향후에도 활용될 수 있어 여기에 게시합니다:
<span>public</span> <span>function</span> runBat(<span>$name</span><span>){ </span><span>if</span>(!<span>file_exists</span>(<span>$name</span>) || !<span>$this</span>-><span>isAuto){ </span><span>return</span><span>; } </span><span>//</span><span>转入后台处理</span> @<span>exec</span>(<span>pclose</span>(<span>popen</span>("start /B ". <span>escapeshellcmd</span>(<span>$name</span>), "r"<span>))); }</span>
이전 index.html에는 인위적으로 추가한 name="noBuild"가 있습니다. 이는 나중에 다른 파일을 필터링하려는 경우 이 식별자로 js 파일을 필터링하고 싶기 때문입니다. , 이것만 추가하면 됩니다. 로고만 있으면 충분합니다. PHP 코드를 변경할 필요가 없습니다. 내부용이므로 프로젝트 경로를 지정하는 폼 항목이 없습니다. 기본적으로 index.html이 있는 상위 디렉터리가 프로젝트 디렉터리입니다. 이 디자인은 작동을 단순화하고 효율성을 향상시킵니다.
특정 파일 탐색과 관련하여 매우 간단한 솔루션인 glob 기능을 권장합니다.
<span>$files</span> = <span>glob</span>(<span>$path</span>.'/*.css',GLOB_NOSORT);
다음은 프로젝트 디렉토리 구조 다이어그램입니다.
또 다른 작업 렌더링:
마지막 처리 결과 사진입니다:
마침내 더 이상 그런트 구성을 작성하고 노드를 설치할 필요가 없습니다. 이제 업데이트할 때 svn에서 많은 노드 항목을 끌어내리는 것에 대해 걱정할 필요가 없습니다.
프런트엔드 코드를 표시하는 것을 잊어버린 것 같습니다.
<span>/*</span><span>* * 选项卡类 * @param {string} id 选项卡的ID </span><span>*/</span> <span>function</span><span> Tabs(id){ </span><span>var</span> node = document.querySelector('#'+<span>id); </span><span>var</span> selected = node.querySelector('.selected'<span>); </span><span>this</span>.selected =<span> selected; </span><span>this</span>.node =<span> node; </span><span>this</span><span>.bindEvent(); } </span><span>/*</span><span>* * 切换选项卡 * @param {object} event 事件 * @return {[type]} [description] </span><span>*/</span><span> Tabs.prototype.change </span>= <span>function</span><span>(event){ </span><span>var</span> element =<span> event.target; </span><span>if</span>(element.tagName.toLowerCase()=='li'<span>){ </span><span>if</span>(element.className=='selected'<span>){ </span><span>return</span><span>; } }</span><span>else</span><span>{ </span><span>while</span>(element != <span>this</span><span>.node){ element </span>=<span> element.parentNode; </span><span>if</span>(element.tagName.toLowerCase()=='li'<span>){ </span><span>break</span><span>; } } </span><span>if</span>(element == <span>this</span>.node) <span>return</span><span>; } </span><span>this</span>.selected.removeAttribute('class'<span>); element.className </span>= 'selected'<span>; </span><span>this</span>.selected =<span> element; </span><span>this</span><span>.content(); } Tabs.prototype.content </span>= <span>function</span><span>(){ </span><span>var</span> form =<span> document.form1; </span><span>switch</span>(<span>this</span><span>.getTabType()){ </span><span>case</span> 'js'<span>: form.style.display </span>= 'block'<span>; form.children[</span>0].innerHTML = '自动压缩JS'<span>; </span><span>break</span><span>; </span><span>case</span> 'css'<span>: form.style.display </span>= 'block'<span>; form.children[</span>0].innerHTML = '自动压缩CSS'<span>; </span><span>break</span><span>; </span><span>default</span><span>: } }</span>
저는 프론트엔드와 백엔드를 모두 알고 있어서 의욕이 넘칩니다. 클릭 한 번으로 걱정은 이제 안녕! 자신만의 도구를 만들고 다른 사람들이 어려운 작업을 하도록 하세요. 정말 쉽습니다!
위 내용은 스스로 할 수 있는 방법과 충분한 음식과 의복을 갖추는 방법에 대한 소개입니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.