我们想 在problem-detail上具体显示代码 建一个component 叫 editor 将ace集成上去,算是他的画布吧。

支持各种语言 可以reset  提交写好的代码到server端编译运行

然后我们就去 problem-detail页面把他加上 也就是在详细页面显示

首先呢 我们还是用那个网格 但是呢?因为我们是想把ace放里面 所以 不适合太小,如果很小,不显示。比较小就占12个,一行。如果是middle就 占8个

所以

下面我们安装ace 一种和auth类似的用法下载源码在publc文件夹下 index.html中引入cdn 但是呢 以后版本更新会很多麻烦

所以我们用命令行安装

安装完成以后呢“?和 安装bootstrap一样 都要再引入才能使用”

以后也会加入C++ PYTHON等

下面我们修改editor的html css 以及逻辑

上面的写法写错了

然后是css

我们从ace官网的API可以了解到 有很多事件

比如 change

所以我们就不用自己写

我们得到这写even或者说变化

通过socket io 传到server 告诉其他所有人这些变化 然后client端接收这些变化

从而达到 同步

我们看看效果

报错

因为他是angular一个保留的用处 不能直接使用,因为,怕xxs注入,比如,我们绑定数值都是{{}}},如果黑客注入,就惨了。如果要使用就加一行  ng-non-bindable

  1. 我们换一种写法
  2. 我们在ts文件里面 string的形式写出来 然后把代码再setValueeditor里面去

就想操作一个dom一样 网页元素一样

我们看效果

就一条很细的线

这是ace的问题 他不能动态的设置大小

也就是他们的height是个固定值

我们只能改下

我们再看看

出现了

有时候写了很多代码,想清除,我们做一个reset的功能

设计一个button 怕用户误按 我们做成弹出框,让用户确认一下

再设计一个下拉菜单,可以选择多个语言

  1. <section>
  2. <header class="editor-header">
  3. <select class="form-control pull-left lang-select" name="language" [(ngModel)]="language" (change)="setLanguage(language)">
  4. <option *ngFor="let language of languages" [value]="language">
  5. {{language}}
  6. </option>
  7. </select>

  8. <!-- reset button -->
  9. <!-- Button trigger modal -->
  10. <button type="button" class="btn btn-default" data-toggle="modal" data-target="#myModal">
  11. <span class="glyphicon glyphicon-refresh" aria-hidden="true"></span>
  12. </button>

  13. <!-- Modal -->
  14. <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  15. <div class="modal-dialog" role="document">
  16. <div class="modal-content">
  17. <div class="modal-header">
  18. <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  19. <h4 class="modal-title" id="myModalLabel">Reset</h4>
  20. </div>
  21. <div class="modal-body">
  22. You will lose current code in the window, are you sure?
  23. </div>
  24. <div class="modal-footer">
  25. <button type="button" class="btn btn-success" data-dismiss="modal" (click)="resetEditor()">Reset</button>
  26. <button type="button" class="btn btn-primary" data-dismiss="modal">Cancel</button>
  27. </div>
  28. </div>
  29. </div>
  30. </div>
  31. </header>
  32.  
  33. <div class="row">
  34. <div id="editor"></div>
  35. </div>


  36. <footer class="editor-footer">
  37. <button type="button" class="btn btn-success pull-right" (click)="submit()">Submit Solution</button>
  38. </footer>
  39. </section>

未下节课预留的submit 就是提交代码的按钮

我们原来的css强制定位不行了 要改

改成

  1. @media screen {
  2. #editor {
  3. height: 600px;
  4. }
  5. .lang-select {
  6. width: 100px;
  7. margin-right: 10px;
  8. }
  9. header .btn {
  10. margin: 0 5px;
  11. }
  12. footer .btn {
  13. margin: 0 5px;
  14. }
  15. .editor-footer, .editor-header {
  16. margin: 10px 0;
  17. }
  18. .cursor {
  19. /*position:absolute;*/
  20. background: rgba(0, 250, 0, 0.5);
  21. z-index: 40;
  22. width: 2px!important
  23. }
  24. }

看看效果

我们在前端加入几个语言

当然这是很简单的 只是加入几个字符串

后端就比较难 下一次做

意思是当我们切换语言,我们会调用resetEditor()方法 切换到那个语言

我们需要更改mode既 语言

和setValue 既 那个字符串模板代码

就是字符串 变量拼接

那么就可以改成

启动的时候重置一下语言

我们写一点代码

提交

无所谓我们写什么 他只是把页面的代码全部返回

切换语言我们完成了

但是当我们切换语言到python

仍然是用的Java的语言高亮

虽然我们已经将setMode对应相符的语言 但是呢 具体的包我们还没引入项目中

我们去angular.json

看看效果

OK python和C++语法高亮有了

17.嵌入ace插件的更多相关文章

  1. Unity中嵌入网页插件Embedded Browser2.1.0

    背景 最近刚换了工作,新公司不是做手游的,一开始有点抵触,总觉得不是做游戏自己就是跨行了,认为自己不对口,但是慢慢发现在这可以学的东西面很广,所以感觉又到了打怪升级的时候了,老子就在这进阶了. 一进公 ...

  2. 前端页面使用ace插件优化脚本

    html页面:<pre id="editor" style="width: 100%;height: 800px;"></pre>(注: ...

  3. 17. Fluentd输出插件:out_copy用法详解

    copy即复制,out_copy的作用就是将日志事件复制到多个输出,这样就可以对同一份日志做不同类型的分析处理. out_copy内置于Fluentd,无需单独安装. 示例配置 <match p ...

  4. django中嵌入百度editor插件

    一.安装和配置步骤: 1.先下载百度ueditor插件,并安装pip install DjangoUeditor 2.把下载好的ueditor插件放到自己的项目中 3.配置setting INSTAL ...

  5. C#开发ActiveX插件-aspx中嵌入

    刚到新的公司,第一周让我熟悉一下他们用的silverlight和arcgis.这周,也就是昨天分配了我一个小小的任务! 哪个项目的不知道,是让我实现一个在aspx中嵌入activeX插件! 在网上找了 ...

  6. GitBook插件整理 - book.json配置

    目录 1. 配置概况 1.1. 全局配置 1.2. 插件列表 plugins 1.3. 插件属性配置pluginsConfig 2. 一些实用插件 2.1. back-to-top-button 回到 ...

  7. 【学习笔记】在原生javascript中使用ActiveX和插件

    什么是插件 现在的浏览器提供了大量的内置功能,但仍然有一些工作无法完成,如播放音频和视频.插件及其扩展浏览器功能就尤为重要. 插件是可下载的应用程序,可以插入到浏览器中,现在有很多不同的插件,常用的有 ...

  8. 精选29款非常实用的jQuery应用插件

    今天我们来分享一些实用的jQuery应用插件,没有特别花哨,但都比较实用,jQuery菜单.jQuery图片都有涉及到,一起来看看. 1.jQuery+CSS3仿IOS无线局域网Wifi DEMO演示 ...

  9. jQuery插件综合应用(四)头像设置

    一.操作流程 会员点击头像设置,弹出一个层,在层中,有上传图片的按钮,用户点击按钮上传图片,图片在服务器端按大小压缩保存(方便剪切).保存后,在前端显示,然后用户可修剪图片.选择图片区域,点击提交,保 ...

随机推荐

  1. 【TensorFlow学习笔记 】name_socpe variable_scope

    [引言]TensorFlow中的命名域是非常重要的概念,涉及到参数共享,方便命名参数管理,定义图结构 本文主要介绍name_scope 和 variable_scope,slim包中的arg_scop ...

  2. mysql中min和max查询优化

    mysql max() 函数的需扫描where条件过滤后的所有行: 在测试环境中重现: 测试版本:Server version:         5.1.58-log MySQL Community ...

  3. selenuim和phantonJs处理网页动态加载数据的爬取

    一.图片懒加载 什么是图片懒加载? 案例分析:抓取站长素材http://sc.chinaz.com/中的图片数据 #!/usr/bin/env python # -*- coding:utf-8 -* ...

  4. windows下解决python输出utf-8中文

    class UnicodeStreamFilter: def __init__(self, target): self.target = target self.encoding = 'utf-8' ...

  5. gt,gte,lt,lte缩写的含义

    gt: greater than 大于 gte: greater than or equal 大于等于 lt: less than 小于 lte: less than or equal 小于等于

  6. java的Map遍历

    java中的map遍历有多种方法,从最早的Iterator,到java5支持的foreach,再到java8 Lambda,让我们一起来看下具体的用法以及各自的优缺点 先初始化一个mappublic ...

  7. Java并发编程:Java Thread 的 sleep() 和 wait() 的区别

      1. start 和 run 方法解释: 1) start: 用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码.通过调用Thread类 ...

  8. gentoo AR9285 BCM57780 安装驱动

    首先使用启动光盘启动, 然后 mount /dev/sda4 /mnt/gentoo 挂载硬盘 lspci -v 1>/mnt/gentoo/root/lspci_v.txt 输出信息到文件. ...

  9. 8.2.1.2-MySQL如何优化 WHERE 语句

    这一章节讨论能够在WHERE处理语句中使用的优化. 样例使用SELECT 语句, 但是同样适用于DELETE,UPDATE语句中的WHERE语句. 注意 因为MYSQL优化器在不断的发展,MySQL执 ...

  10. uva-317-找规律

    无耻的抄袭了结果,三组数,从每一组数中选取一个数组成正六边形的对边,总共会有27个正六边形,从27个小六边形中选取19个组成大六边形,求大六边形的最大值 #include<iostream> ...