layui.upload多文件上传怎么兼容IE8啊? 20C

图片说明这种效果的上传,在IE8里面选择文件后框里没有文件信息,其他浏览器里都是可以的,,就IE8不行,请问这个怎么才能兼容IE8。附上代码图图片说明

weixin_44339669
多幸运遇见你 ie9兼容吗
14 天之前 回复
weixin_44339669
多幸运遇见你 ie9兼容吗
14 天之前 回复

1个回答

可以看一个后台框架H-ui.admin,里面有一个图像管理界面就是兼容了IE8的,只是我没看懂

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
点击按钮 使用layui怎么打开一个textarea? 并点击确定向后台发送数据?求大神
![图片说明](https://img-ask.csdn.net/upload/201910/18/1571389330_631630.png) 如图,js怎么写啊?刚接触layui还不太会.部分js如下 ``` layui.config({ base: '/modules/' //静态资源所在路径 }).use(['jquery','layer','jmdf'], function () { var $ = layui.jquery,layer = layui.layer,jmdf = layui.jmdf; $("button[type=button]").click(function () { alert($(this).val()) }) ```
大神们求帮助!layui行内工具栏怎么做判断
![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267680_397076.png) ``` <!--行内工具栏--> <script type="text/html" id="barDemo"> <a class="layui-btn layui-btn-radius layui-btn-xs" lay-event="fahuo" >发货</a> <a class="layui-btn layui-btn-radius layui-btn-xs" lay-event="particulars" >详情</a> </script> ``` ![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267715_449356.png) ``` <script> layui.use([ 'table', 'form', 'layer' ], function() { var table = layui.table; var form = layui.form; var layer = layui.layer; //var $ = layui.$;//用不到jq table.render({ elem : '#demo', //height: 432,//都不分页了也不设置高度了,自适应有多少显示多少 url : 'adminSelectOrder', method : 'post', //where: {//不需要token,也就不需要条件 // 'token': globalData.myToken //}, title : '订单表', toolbar : '#topToolbar', page : true, // 等等... ``` ![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267776_835625.png) 我想根据订单状态来显示这个发货按钮,比如:订单为待发货时才显示发货这个按钮,大神们怎么判断,教一下,受小弟一拜!!! 谢谢啦
使用jspsmart.upload组件上传文件总是上传不上,跪求指点
JSP body区: <% SmartUpload su=new SmartUpload(); su.initialize(pageContext); su.upload(); int num=su.save("/file/", SmartUpload.SAVE_VIRTUAL); out.println(num+"个文件上传成功!!!<br>"); %> 已经把组件的包导进去了 <%@ page language="java" import="java.util.*,com.jspsmart.upload.*" pageEncoding="UTF-8"%> 运行不会报错,但就是现实"0个文件上传成功!!!"。求懂得大神指点一下吧 < form action="/webserver/web/display.jsp" method="post" ENCTYPE="multipart/form-data">< input type="file" size="40">< input type="file" size="40">< input type="submit" value="上传">< /form>
SpringMvc+layui 实现图片上传更新头像 但是总弹出接口异常(很急!!!!)
![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713715_871569.png) **前端请求时候 url 500** ``` <script src="${pageContext.request.contextPath}/resources/layui.all.js"></script> <script> $ = layui.$; var $ = layui.jquery var form = layui.form; var element=layui.element; var layer=layui.layer; var upload = layui.upload; $("#nav").load("/filmos/nav"); upload.render({ elem: '#choose' , auto: false , url: '${pageContext.request.contextPath}/user/updateuserimg' ,accept: 'file' , bindAction: '#upload' , choose: function (obj) {//选择文件的回调,obj为选中的文件 //将每次选择的文件追加到文件队列 var files = obj.pushFile(); //预览选中的文件(本地文件) obj.preview(function (index, file, result) { $('#user-img').attr('src', result); $('#upload').css('display', 'block'); }); } , before: function (obj) {//文件上传前的回调 } , done: function (res) { if (res.code==200) { location.href = "${pageContext.request.contextPath}/ok" }else { //演示失败状态,并实现重传 return layer.msg(res.msg); } } ,error: function(res) { console.log(res); console.log(res.code); console.log(res.msg); var demoText = $('#demoText'); demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>'); demoText.find('.demo-reload').on('click', function () { uploadInst.upload(); }); } }); </script> </body> </html> ``` **js代码** ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713861_529370.png) **但是实际上功能是实现了的 数据库中也更新了 但是每次都会弹出接口异常** ``` //上面还有个requestmapping是user 通过user/updateuserimg到这个方法 @ResponseBody @RequestMapping(value = "/updateuserimg", method = {RequestMethod.POST,RequestMethod.GET}) private JSONObject updateUserImg(@RequestParam(value = "file", required = false) CommonsMultipartFile multipartFile, HttpSession session) throws IOException{ User user = (User) session.getAttribute("user"); JSONObject jsonObject=new JSONObject(); if (multipartFile != null && multipartFile.getSize() > 0&& user!=null) { userService.updateUserImg(user, multipartFile.getInputStream(), multipartFile.getOriginalFilename()); session.setAttribute("user", userService.login(user)); jsonObject.put("code",200); jsonObject.put("msg","更新成功!"); jsonObject.put("src",user.getUserImg()); return jsonObject; } else { jsonObject.put("code",400); jsonObject.put("msg","更新失败!"); return jsonObject; } } } ``` Contoller的代码 ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558713969_417859.png) ssm配置的 ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714077_867660.png) ![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714083_361418.png)![图片说明](https://img-ask.csdn.net/upload/201905/25/1558714089_172810.png)
Jquery.form.js 跨域上传文件IE9异常
Jquery.form.js 跨域上传文件,chrome都能正常得到返回值,而IE一直是返回当前页面的HTML![![图片说明](https://img-ask.csdn.net/upload/201611/23/1479902631_839081.jpg)图片说![![图片说明](https://img-ask.csdn.net/upload/201611/23/1479902716_782194.jpg)图片说明](![图片说明](https://img-ask.csdn.net/upload/201611/23/1479902736_167122.jpg)
iis8.5 Sunrise.Web.Upload.HttpUploadModule 异常
最近换成了win2012+IIS8.5服务器,原来的一个VS的老项目发布后其它页面都没问题,就是调用了一个上传文件的Sunrise.Web.Upload.DLL控件出错,附件不管上传没上传 一点保存就出错,如下: [NullReferenceException: 未将对象引用设置到对象的实例。] Sunrise.Web.Upload.HttpUploadModule.Application_BeginRequest(Object sender, EventArgs e) +5982 System.Web.SyncEventExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +80 System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +171
使用jquery.uploadify上传文件时在IE下抛出Error#1069
使用jquery.uploadify-v2.1.4 上传文件时在IE下抛出如**下图**所示错误,想请教各位前辈是否碰到类似情况,该如何解决呢? ![图片说明](https://img-ask.csdn.net/upload/201608/26/1472193972_70050.png)
layui的分页+模糊查询
layui.use('upload', function(){ var upload = layui.upload; var $ = layui.jquery layui.use('table', function(){ var table = layui.table,//表格 laypage = layui.laypage,//分页 layer = layui.layer; //弹层 //执行一个 table 实例 table.render({ elem: '#kwgroup_table', height: 620, url: '/spRestCon/findShangPin', //数据接口 title: '商品表', page: true, //开启分页 toolbar: 'default', //开启工具栏,此处显示默认图标,可以自定义模板,详见文档 //totalRow: true, //开启合计行 cols: [[ //表头 //fixed: 'left', {field: 'id', title: '商品ID',sort: true, width:50}, {field: 'productName', title: '商品名称', width:100}, {field: 'money', title: '商品价格', width: 80}, {field: 'createdate', title: '添加时间', width:110}, {fixed: 'right',title:'商品信息操作', width: 135, align:'center', toolbar: '#operation'} ]] }); //分页 laypage.render({ elem : 'paging', // 分页容器的id skin : '#1E9FFF', // 自定义选中色值 jump : function(obj, first) { if (!first) { layer.msg('第' + obj.curr + '页', { offset : 'b' }); } } }); //监听行工具事件 table.on('tool(kwgroup_table)', function(obj){ //注:tool 是工具条事件名,test 是 table 原始容器的属性 lay-filter="对应的值" var data = obj.data //获得当前行数据 ,layEvent = obj.event; //获得 lay-event 对应的值 if(layEvent === 'del'){ var delId=data.id; layer.confirm('是否删除此商品', function(index){ obj.del(); //删除对应行(tr)的DOM结构 layer.close(index); //向服务端发送删除指令 $.get("","id="+delId,function(rv){ if(rv.falg==false){ layer.msg('删除失败'); }else{ layer.msg('已删除'); } }); }); } else if(layEvent === 'edit'){ layer.confirm('选择操作', { btn: ['添加', '修改', '取消'] //可以无限个按钮 ,btn1: function(index, layero){ layer.msg('按钮1'); },btn2: function(index, layero){ layer.msg('按钮2'); } }); }else if(layEvent === 'upd'){ layer.msg('编辑操作'); } }); }); $('#btn').click(function(){ var spName=$("#spName").val().trim(); var page=$(".layui-laypage-limits").find("option:selected").val();//获取分页数目 var limit=$(".layui-laypage-em").next().html();//获取当前页码值 alert(page); alert(limit); if(spName==null){ alert(spName); }else{ $.get("/spRestCon/findShangPin", "productName="+spName+ "&page="+page+ "&limit="+limit, function(rv){ },"json"); } }); }); 我把文本框写入的值传到后台拿到返回值之后怎么展示模糊查询的数据? 是把上面那一片layui的模板代码把他们放在一个方法体里在拿到返回值的ajax方法体里调用还是怎么弄? SOS~
使用jquery.uploadify上传文件时在IE下抛出: 在String上找不到Name
使用jquery.uploadify2.1.4多次上传同一个文件时,在IE11下抛出入下图所示错误,不知各位前辈是否有遇到类似问题,如何解决的呢?望指教,非常感谢~ ![图片说明](https://img-ask.csdn.net/upload/201608/27/1472304455_114419.png)
PDF.js在IE10的兼容问题:“Map”未定义
最近在搞一个PDF在线预览的功能,于是选择了PDF.js,但是中途问题很多, 由于项目要兼容IE10,但是 PDF.js对于IE的兼容不是很好,中途也解决了很 多坑,这两天在IE10下有遇见了一个问题“Unhandled promise rejection UnknownErrorException: “Map”未定义”,错误没有具体报错的行号和是哪个脚本,如图: ![图片说明](https://img-ask.csdn.net/upload/201909/05/1567664121_686875.png) 错误导致在IE10版本功能没有办法正常运行,有没有前端大佬遇见过类似的情况或者能分析出问题所在的望能给指点一下迷津!!! 问题很急,非常感谢!!!!
使用angular-file-upload.js上传,发现在IE9下不兼容
![图片说明](https://img-ask.csdn.net/upload/201609/05/1473048649_811298.jpg) 选中要上传的文件后,在输入框中没有显示出上传的文件名;可以看到输入框中还是空白的。 把nv-file-select=""去掉之后才可以显示出选中上传的文件,该怎么才能解决这个问题。 求有哪位大神有好多解决办法。
angular1.5.8怎么才能支持ie8?
![图片说明](https://img-ask.csdn.net/upload/201710/12/1507800619_284794.png) angular在ie8下这一行报错
用window.navigator.userAgent获取字符串判断是否ie8?
用window.navigator.userAgent获取字符串判断是否ie8,但是我用360浏览器切换不起作用,始终显示ie9 ![图片说明](https://img-ask.csdn.net/upload/201803/08/1520481649_140635.png)
IE10下JSON.stringify()不兼容怎么解决?
IE10 下JSON.stringify()不兼容 ,其他浏览器都可以正常使用,IE8的话由于个人电脑不支持暂没测试, 使用josn2.js的方法 没有任何效果。 ![图片说明](https://img-ask.csdn.net/upload/201508/16/1439698162_937799.png)
layui数据渲染中遇到的问题....
![图片说明](https://img-ask.csdn.net/upload/201907/30/1564465451_583411.png) ** 有已审核和未审核两个功能,我的想法就是根据后端传我的is_audit(是否审核)来判断渲染,用的是公共的一个js,在两个html页面进行判断,用的layui模板引擎** ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564465999_808679.png) **在each里面循环判断** ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564466091_968288.png) ![图片说明](https://img-ask.csdn.net/upload/201907/30/1564466053_36856.png) **结果就成了这样**
Java新手求助,动态下拉列表
项目用LayUi框架+SpringMvc实现的 点击总体页面右侧的编辑按钮弹出Layui渲染的窗口(另一个jsp页),窗口中的下拉列表想做成从后端数据库表中查出的数据 ![图片说明](https://img-ask.csdn.net/upload/201706/07/1496817409_419946.png) 整体页: ``` <fieldset class="layui-elem-field"> <legend>诉讼指南列表</legend> <div class="layui-field-box layui-form"> <table class="layui-table admin-table"> <thead> <tr> <th style="width: 30px;"><input type="checkbox" lay-filter="allselector" lay-skin="primary"></th> <th>标题</th> <th>日期</th> <th>分类</th> <th>操作</th> </tr> </thead> <tbody id="content"> </tbody> </table> </div> </fieldset> <div class="admin-table-page"> <div id="paged" class="page"> </div> </div> <script type="text/html" id="tpl"> {{# layui.each(d.list, function(index, item){ }} <tr> <td><input type="checkbox" lay-skin="primary"></td> <td>{{ item.heading }}</td> <td>{{ item.dates }}</td> <td>{{ item.litigationguidesubmenu.litigationguidesubmenuname }}</td> <td> <!-- 修改按钮 --> <a href="javascript:;" data-gid="{{ item.gid }}" data-heading="{{ item.heading }}" data-straightmatter="{{ item.straightmatter }}" data-dates="{{ item.dates }}" data-opt="edit" class="layui-btn layui-btn-mini" id="update" onclick="edit(this)">编辑</a> <a href="javascript:;" data-gid="{{ item.gid }}" data-opt="del" id="del" class="layui-btn layui-btn-danger layui-btn-mini" onclick="del(this)">删除</a> </td> </tr> {{# }); }} </script> <script type="text/javascript" src="${pageContext.request.contextPath }/plugins/layui/layui.js"></script> <script> layui.config({ base: 'js/' }); layui.use(['paging', 'form'], function() { var $ = layui.jquery, paging = layui.paging(), layerTips = parent.layer === undefined ? layui.layer : parent.layer, layer = layui.layer, form = layui.form(); paging.init({ /* 省略查询代码 */ complate: function() { //点击编辑按钮弹出编辑窗口 $.post('view/LitigationGuide/forms/updateForm.jsp',{gid:$(this).data('gid'),heading:$(this).data('heading'),straightmatter:$(this).data('straightmatter'),dates:$(this).data('dates'),submenu:$(this).data('submenu')}, function(form) { addBoxIndex = layer.open({ type: 1, title: '修改诉讼指南', content: form, btn: ['保存', '取消'], shade: false, offset: ['100px', '30%'], area: ['800px', '620px'], zIndex: 19950924, maxmin: true, yes: function(index) { //触发表单的提交事件 $('form.layui-form').find('button[lay-filter=edit]').click(); }, success: function(layero, index) { //弹出窗口成功后渲染表单 var form = layui.form(); form.render(); form.on('submit(edit)', function(data) { //参数传入controller $.post('litigationguide/updateLitigationGuide.json',data.field,function(res){ location.reload(); }); return false; }); }, end: function() { addBoxIndex = -1; } }); }); }); }); }, }); </script> ``` updateForm.jsp: ``` <html> ... <body> <!--省略标题、正文、日期等...--> <div class="layui-form-item" style="width:200px; margin-left:110px;"> <select name="fenlei" lay-verify="" > <option value="">请选择文章分类</option> <c:forEach items="${ 后台返回的集合 }" var="s"> <option value="${ s.id }">${ s.值 }</option> </c:forEach> </select> </div> ... </body> ... </html> ``` 小白还求高手指教
使用layui的富文本编辑器 上传图片后不能显示图片 只能显示图片名
![图片说明](https://img-ask.csdn.net/upload/201903/23/1553320913_930043.png)![图片说明](https://img-ask.csdn.net/upload/201903/23/1553320929_255574.png) <div class="layui-form-item layui-form-text"> <label class="layui-form-label">历史</label> <div class="layui-input-block"> <textarea id="history" name="article_desc" lay-verify="article_desc" placeholder="" class="layui-textarea">请输入历史</textarea> </div> <input type="hidden" id="introCont"> </div> ``` <!--编辑器--> <script> layui.use(['layedit','form'], function(){ var layedit = layui.layedit,$ = layui.jquery,form = layui.form; //构建一个默认的编辑器 layedit.set({ uploadImage: { url: '/File/uploadImg', type: 'post' } }); var index = layedit.build('history',{tool: [ 'strong' //加粗 ,'italic' //斜体 ,'underline' //下划线 ,'del' //删除线 ,'|' //分割线 ,'left' //左对齐 ,'center' //居中对齐 ,'right' //右对齐 ,'link' //超链接 ,'unlink' //清除链接 ,'face' //表情 ,'image' //插入图片 // ,'help' //帮助 ]}); //自定义验证规则 form.verify({ history: function(value){ if(value.length < 0){ return '历史不能为空'; } } ,article_desc: function(value){ layedit.sync(index); } }); //编辑器外部操作 var active = { content: function(){ //alert(layedit.getContent(index)); //获取编辑器内容 var str = layedit.getContent(index); //赋值到隐藏的标签 $("#introduce").val(""+ str +""); //console.log("视频简介内容:"+ $("#introCont").val()) } }; $('.layui-textarea').on('click', function(){ var type = $(this).data('type'); active[type] ? active[type].call(this) : ''; }); }); </script> ``` package com.yunce.web.controller; import com.yunce.web.Setting; import com.yunce.web.utils.FileUpload; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletRequest; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.Map; /** * Created by Administrator on 2019/3/22. */ @Controller @RequestMapping(value = "/File") public class FileController { public static Logger LOG = LoggerFactory.getLogger(FileController.class); @Autowired private Setting setting; @RequestMapping(value = "/uploadImg", method = RequestMethod.POST) @ResponseBody public Map<String, Object> uploadImg(@RequestParam (value = "file")MultipartFile[] files, HttpServletRequest request) { String url = setting.local_url; String saveFilePath = setting.image_dir; Map<String, Object> map = new HashMap<>(); Map<String, Object> data = new HashMap<>(); for (int i = 0, length = files.length; i < length; i++) { if (files[i] != null && !files[i].isEmpty()) { LOG.info("图片大小:" + files[i].getSize() / 1024 + "KB"); //获取图片的文件名 String fileName = files[i].getOriginalFilename(); //获取图片的扩展名 String extensionName = fileName.substring(fileName.lastIndexOf(".") + 1); //新的图片文件名 = 年月日+随机数 +"."图片扩展名 String dateStr = new SimpleDateFormat("yyyyMMdd").format(new Date()); Integer num = (int) ((Math.random() * 9 + 1) * 100000); String newFileName = String.valueOf(dateStr + num) + "." + extensionName; FileUpload.saveFile(newFileName, files[i], saveFilePath); url = url + "/" + newFileName; data.put("src", url); data.put("title", newFileName); map.put("code", 0); map.put("msg", "上传成功"); map.put("data", data); } } return map; } } /* String tempPath="f:/upload"; Map<String,Object> map=new HashMap<>(); Map<String,Object> data=new HashMap<>(); String oldName=file.getOriginalFilename(); System.out.println("图片名字:oldName is:"+oldName); String tempName = System.currentTimeMillis() + ""; System.out.println("tempName is:" +tempName); //以文件名命名的文件夹 String tempFileDir = tempPath + "/" + tempName; File parentFileDir = new File(tempFileDir); //若不存在 就新建 if (!parentFileDir.exists()) { parentFileDir.mkdirs(); } //新文件名 获取当前名+文件后缀 String newName = tempName + oldName.substring(oldName.lastIndexOf(".")); //数据库img的src String src="/upload/"+tempName+"/"+newName; System.out.println("图片名字:newName is:"+newName); try { //存放文件 (文件名,文件) file.transferTo(new File(tempFileDir,newName)); } catch (IllegalStateException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }*/ ``` ```
layui中dropdown的选择项怎么点击 跳转别的页面
![图片说明](https://img-ask.csdn.net/upload/201910/22/1571725083_125762.jpg) dropdown.render({ elem: $view.find('.action-more'), click: function (name, elem, event) { var checkStatus = table.checkStatus('talentTable'); // if (name === 'add') { // febs.modal.open('新增人才信息', 'system/talent/add', { // btn: ['上一步', '下一步','提交', '取消'], // btn1:function(){ // $("#preBtn").trigger('click') // return false; // }, // btn2:function(){ // $("#nextBtn").trigger('click') // return false // }, // btn3: function (index, layero) { // var msg = checkVaild() // if (msg != null) { // febs.alert.error(msg); // return false; // } // $('#talent-add').trigger('click'); // $query.trigger('click'); // // layer.closeAll(); // layer.msg("添加成功!") // return false // }, // btn4: function () { // layer.closeAll(); // return false; // } // }); // } //隐藏部分为点击出现弹窗的代码 if(name ==='add'){ parent.layui.index.openTabsPage('system/talent/add','新增人才信息'); } //以上为点击跳转tab页的代码,未实现,求方法 if (name === 'delete') { if (!checkStatus.data.length) { febs.modal.warn('请选择需要删除的人才信息'); } else { febs.modal.confirm('删除人才信息', '确定删除该人才信息?', function () { var talentIds = []; layui.each(checkStatus.data, function (key, item) { talentIds.push(item.id); }); deleteTalents(talentIds.join(',')); }); } } if (name === 'export') { var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type}); params.pageSize = $view.find(".layui-laypage-limits option:selected").val(); params.pageNum = $view.find(".layui-laypage-em").next().html(); febs.download(ctx + 'talent/export', params, '人才信息表.xls'); } if (name === 'template-download') { febs.download(ctx + 'talent/template', null, '人才数据表Excel导入模板.xls'); } }, options: [{ name: 'add', title: '新增', perms: 'talent:add' }, { name: 'delete', title: '批量删除', perms: 'talent:delete' }, { name: 'export', title: '导出Excel', perms: 'talent:export' }, { name: 'template-download', title: '模板下载', perms: 'talent:template' }] });
layui动态生成多个相同select框,如何使之间赋值互不影响?
![图片说明](https://img-ask.csdn.net/upload/201811/08/1541670449_678465.jpg) 下拉框如上,里面有两个选值(动态赋值),当点击加号键动态生成一个相同的下拉框时 ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541670559_526955.jpg) 上面的下拉框就会重复赋值如下 ![图片说明](https://img-ask.csdn.net/upload/201811/08/1541670612_944433.jpg) 该怎么解决?(前端小白,页面用的是layui)
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
相关热词 c#委托 逆变与协变 c#新建一个项目 c#获取dll文件路径 c#子窗体调用主窗体事件 c# 拷贝目录 c# 调用cef 网页填表c#源代码 c#部署端口监听项目、 c#接口中的属性使用方法 c# 昨天
立即提问