<!DOCTYPE html> <html lang="zh"> <head> <meta charset="utf-8" /> <title>Chnage mode - Editor.md examples</title> <link rel="stylesheet" href="css/style.css" /> <link rel="stylesheet" href="../css/editormd.css" /> <link rel="shortcut icon" href="https://pandao.github.io/editor.md/favicon.ico" type="image/x-icon" /> <style> #codes textarea {display: none;} </style> </head> <body> <div id="layout"> <header> <h1>Chnage mode</h1> <p>Become to the code editor</p> <p>Modes : <select id="modes"> <option value="">select modes</option> </select> Themes : <select id="themes"> <option selected="selected" value="">select themes</option> </select> </p> </header> <div class="btns"> <button id="get-code-btn">Get code source</button> <button id="fullscreen-btn">Fullscreen (Press F11 into, ESC exit)</button> </div> <div id="codes"> <textarea id="html-code"><!DOCTYPE html> <html lang="zh"> <head> <meta charset="utf-8" /> <title>Chnage mode - Editor.md examples</title> <link rel="stylesheet" href="css/style.css" /> <link rel="stylesheet" href="../css/editormd.css" /> <link rel="shortcut icon" href="https://pandao.github.io/editor.md/favicon.ico" type="image/x-icon" /> </head> <body> <div id="layout"> <header> <h1>Chnage mode</h1> </header> <div id="test-editormd"> <textarea style="display:none;"></textarea> </div> </div> <script src="js/jquery.min.js"></script> <script src="../editormd.js"></script> <script type="text/javascript"> $(function() { var testEditor = editormd("test-editormd", { width : "90%", height : 720, watch : false, toolbar : false, codeFold : true, searchReplace : true, placeholder : "Enjoy coding!", value : (localStorage.mode) ? $("#"+localStorage.mode.replace("text/", "")+"-code").val() : $("#html-code").val(), theme : (localStorage.theme) ? localStorage.theme : "default", mode : (localStorage.mode) ? localStorage.mode : "text/html", path : '../lib/' }); }); </script> </body> </html></textarea> <textarea id="javascript-code">$(function() { var testEditor = editormd("test-editormd", { width : "90%", height : 720, watch : false, toolbar : false, codeFold : true, searchReplace : true, placeholder : "Enjoy coding!", value : (localStorage.mode) ? $("#"+localStorage.mode.replace("text/", "")+"-code").val() : $("#html-code").val(), theme : (localStorage.theme) ? localStorage.theme : "default", mode : (localStorage.mode) ? localStorage.mode : "text/html", path : '../lib/' }); });</textarea> <textarea id="xml-code"><?xml version="1.0" encoding="utf-8" ?> <root> <photo url="https://pandao.github.io/editor.md/examples/images/7.jpg"> <title>李健首张专辑《似水流年》封面</title> <width>360</width> <height>360</height> </photo> <photo url="https://pandao.github.io/editor.md/examples/images/7.jpg"> <title>李健首张专辑《似水流年》封面</title> <width>360</width> <height>360</height> </photo> <photo url="https://pandao.github.io/editor.md/examples/images/7.jpg"> <title>李健首张专辑《似水流年》封面</title> <width>360</width> <height>360</height> </photo> </root></textarea> <textarea id="ruby-code">#!/usr/bin/ruby puts "Hello World!"; # Ruby knows what you # mean, even if you # want to do math on # an entire Array cities = %w[ London Oslo Paris Amsterdam Berlin ] visited = %w[Berlin Oslo] puts "I still need " + "to visit the " + "following cities:", cities - visited</textarea> <textarea id="json-code">{ "employees": [ { "firstName" : "Bill", "lastName" : "Gates" }, { "firstName" : "George", "lastName" : "Bush" }, { "firstName" : "Thomas", "lastName" : "Carter" } ], "employees": [ { "firstName" : "Bill", "lastName" : "Gates" }, { "firstName" : "George", "lastName" : "Bush" }, { "firstName" : "Thomas", "lastName" : "Carter" } ], }</textarea> <textarea id="php-code"><?php $app = new Phalcon\Mvc\Micro(); //Set a route with the name "show-post" $app->get('/blog/{year}/{title}', function ($year, $title) use ($app) { //.. show the post here return $year.$title; })->setName('show-post'); $app->get('/', function () { echo "<h1>Welcome !</h1>"; echo $app->url->get(array( 'for' => 'show-post', 'title' => 'php-is-a-great-framework', 'year' => 2012 )); }); $app->get('/posts/{year:[0-9]+}/{title:[a-zA-Z\-]+}', function ($year, $title) { echo "<h1>Title: $title</h1>"; echo "<h2>Year: $year</h2>"; }); //Requiring another file $app->get('/show/results', function () { require 'views/results.php'; }); //Returning a JSON $app->get('/get/some-json', function () { echo json_encode(array("some", "important", "data")); }); //This route makes a redirection to another route $app->post('/old/welcome', function () use ($app) { $app->response->redirect("new/welcome"); }); $app->post('/new/welcome', function () use ($app) { echo 'This is the new Welcome'; }); /* //Matches if the HTTP method is POST $app->post('/api/products/add', "add_product"); //Matches if the HTTP method is PUT $app->put('/api/products/update/{id}', "update_product"); //Matches if the HTTP method is DELETE $app->put('/api/products/remove/{id}', "delete_product"); //Matches if the HTTP method is GET or POST $app->map('/repos/store/refs')->via(array('GET', 'POST')); */ $app->handle(); ?></textarea> <textarea id="cpp-code">#include "dialog.h" #include <QApplication> int main(int argc, char *argv[]) { QApplication a(argc, argv); Dialog w; w.show(); return a.exec(); }</textarea> <textarea id="java-code">package com.demo.blog; import com.jfinal.aop.Before; import com.jfinal.core.Controller; @Before(BlogInterceptor.class) public class BlogController extends Controller { public void index() { setAttr("blogPage", Blog.me.paginate(getParaToInt(0, 1), 10)); render("blog.html"); } public void add() { } @Before(BlogValidator.class) public void save() { getModel(Blog.class).save(); redirect("/blog"); } public void edit() { setAttr("blog", Blog.me.findById(getParaToInt())); } @Before(BlogValidator.class) public void update() { getModel(Blog.class).update(); redirect("/blog"); } public void delete() { Blog.me.deleteById(getParaToInt()); redirect("/blog"); } } </textarea> <textarea id="actionscript-code">package com.flite { import flash.net.*; import flash.events.*; import flash.display.*; /** * @package com.flite * @class XMLLoader * @author pandao pandao@vip.qq.com */ public class XMLLoder { public var xml:XML; public var url:String; public var list:XMLList; public var percent:Number = 0; public var onload:Function; public var onerror:Function; public var onpreload:Function; public var onprogress:Function; private var loader:URLLoader; public function XMLLoder(url:String) : void { this.url = url; xml = new XML(); xml.ignoreWhite = true; loader = new URLLoader(); loader.load(new URLRequest(url)); loader.addEventListener(Event.OPEN, preloadHandler); loader.addEventListener(IOErrorEvent.IO_ERROR, errorHandler); loader.addEventListener(ProgressEvent.PROGRESS, progressHandler); loader.addEventListener(Event.COMPLETE, loadedHandler); } private function preloadHandler(event:Event) : void { onpreload = onpreload || new Function; onpreload(event); } private function errorHandler(event:IOErrorEvent) : void { onerror = onerror || new Function; onerror(event); } private function progressHandler(event:ProgressEvent) : void { percent = Math.round((event.bytesLoaded / event.bytesTotal) * 100); onprogress = onprogress || new Function; onprogress(event, percent); } private function loadedHandler(event:Event) : void { xml = XML(loader.data); onload = onload || new Function; onload(xml); } } }</textarea><textarea id="perl-code">#!/usr/bin/perl use strict; use warnings; print "Hello, World...\n"; </textarea> <textarea id="go-code">package main import ( "github.com/astaxie/beego" ) type MainController struct { beego.Controller } func (this *MainController) Get() { this.Ctx.WriteString("hello world") } func main() { beego.Router("/", &MainController{}) beego.Run() }</textarea><textarea id="python-code">#!/usr/bin/env python from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello World!' if __name__ == '__main__': app.run()</textarea> <textarea id="css-code"> body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote, th,td,hr,button,article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section { margin:0;padding:0; } article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary { display: block; } audio, canvas, video { display: inline-block; } body, button, input, select, textarea { font:12px/1.5 Tahoma, "Hiragino Sans GB", "Microsoft Yahei", Arial; } body { font-size:12px; color:#666; background:#fff url(../images/) no-repeat left top; } a { color:#444; text-decoration: none; } a:hover { color:#065BC2; text-decoration: none; } .clear { zoom:1; } .clear:after { content:""; height:0; visibility:hidden; clear:both; display:block; } img { border:none; vertical-align: middle; } ul { list-style: none; }</textarea></div> <div id="test-editormd"> <textarea style="display:none;"></textarea> </div> </div> <script src="js/jquery.min.js"></script> <script src="../editormd.js"></script> <script type="text/javascript"> var testEditor; function getCodeValue() { return (localStorage.modeName) ? $("#"+localStorage.modeName.replace("text/", "").replace("c/c++", "cpp")+"-code").val() : $("#html-code").val(); } $(function() { testEditor = editormd("test-editormd", { width : "90%", height : 720, watch : false, toolbar : false, codeFold : true, searchReplace : true, placeholder : "Enjoy coding!", value : getCodeValue(), theme : (localStorage.theme) ? localStorage.theme : "default", mode : (localStorage.mode) ? localStorage.mode : "text/html", path : '../lib/' }); $("#get-code-btn").bind("click", function() { alert(testEditor.getValue()); }); $("#fullscreen-btn").bind("click", function() { testEditor.fullscreen(); }); var select = $("#themes"); for (var i = 0, len = editormd.themes.length; i < len; i ++) { var theme = editormd.themes[i]; var selected = (localStorage.theme == theme) ? " selected=\"selected\"" : ""; select.append("<option value=\"" + theme + "\"" + selected + ">" + theme + "</option>"); } select.change(function(){ var theme = $(this).val(); if (theme == "") { alert("theme == \"\""); return false; } localStorage.theme = theme; testEditor.setTheme(theme); }); var modesSelect = $("#modes"); var modeNames = ["text/html", "javascript", "php", "text/xml", "text/json", "java", "actionscript", "perl", "go", "python", "c/c++", "css", "ruby"]; var modes = ["text/html", "javascript", "php", "text/xml", "text/json", "clike", "javascript", "perl", "go", "python", "clike", "css", "ruby"]; for (var i = 0, len = modes.length; i < len; i ++) { var mode = modes[i]; var selected = (localStorage.modeName == modeNames[i]) ? " selected=\"selected\"" : ""; modesSelect.append("<option value=\"" + mode + "\"" + selected + " name=\"" + modeNames[i] + "\"" + selected + ">" + modeNames[i] + "</option>"); } modesSelect.change(function(){ var mode = $(this).val(); var modeName = $(this).find("option:selected").attr("name"); if (mode == "") { alert("mode == \"\""); return false; } localStorage.mode = mode; localStorage.modeName = modeName; var code = getCodeValue(); testEditor.setCodeMirrorOption("mode", mode); //testEditor.setCodeMirrorOption("value", code); testEditor.setValue(code); }); }); </script> </body> </html>