小编Nat*_*end的帖子

WPF:多个屏幕

我正在WPF中编写一个屏幕保护程序.我有屏幕保护程序工作,但它只显示在我的主显示器上.当用户有多个显示器时,有没有办法"遮挡"或将图形绘制到其他监视器?我做了一些搜索,但没有找到任何相关的东西.

UPDATE

从ananthonline的答案中,我能够使用以下窗口在非主显示器上完成"黑屏"效果:

<Window x:Class="ScreenSaver.BlackOut"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Cursor="None" WindowStyle="None" ResizeMode="NoResize" Background="Black">
</Window>
Run Code Online (Sandbox Code Playgroud)

App.xaml.cs使用以下过程为每个屏幕初始化一个:

foreach (Screen s in Screen.AllScreens)
{
    if (s != Screen.PrimaryScreen)
    {
        BlackOut blackOut = new BlackOut();
        blackOut.Top = s.WorkingArea.Top;
        blackOut.Left = s.WorkingArea.Left;
        blackOut.Width = s.WorkingArea.Width;
        blackOut.Height = s.WorkingArea.Height;
        blackOut.Show();
    }
}
Run Code Online (Sandbox Code Playgroud)

请注意System.Windows.Forms,访问Screen该类需要导入.

c# wpf screensaver

8
推荐指数
1
解决办法
9509
查看次数

如何在定义为"any"的第三方TypeScript接口中扩充属性?

给定第三方TypeScript模块,如下所示:

// in /node_modules/third-party-module/index.d.ts
declare module 'ThirdPartyModule' {
    export interface ThirdPartyInterface {
        data: any;
    }
}
Run Code Online (Sandbox Code Playgroud)

如何扩充此模块以更严格地键入data属性?

我试过这个:

// in /app/typings.d.ts
declare module 'ThirdPartyModule' {

    interface IMyCustomType {}

    interface ThirdPartyInterface {

        // causes a compiler error: Subsequent property declarations 
        // must have the same type.  Property 'data' must be of type 
        // 'any', but here has type 'IMyCustomType'.
        data: IMyCustomType;
    }
}
Run Code Online (Sandbox Code Playgroud)

但这给了我一个编译器错误:"后续属性声明必须具有相同的类型.属性'数据'必须是'any'类型,但这里的类型为'IMyCustomType'."

如果第三方模块将属性定义为实际类型,如下所示:

// in /node_modules/third-party-module/index.d.ts
declare module 'ThirdPartyModule' {
    interface IAnotherThirdPartyInterface {
        something: string;
    }

    interface …
Run Code Online (Sandbox Code Playgroud)

module interface typescript

8
推荐指数
1
解决办法
1773
查看次数

使用.NET JavaScriptSerializer.Deserialize与客户端的DateTime

我正在使用该JavaScriptSerializer.Deserialize<>()方法将从客户端收到的JSON转换为自定义C#类.该类的一个属性是a DateTime.目前该Deserialize<>()方法抛出一个错误,说

"(我的日期字符串)"不是DateTime的有效值.

我尝试使用几种不同的格式发送日期,包括由各种内置JavaScript Date()方法生成的刻度和其他格式,但它们都没有用.

Deserialize<>()方法究竟是什么格式才能将其解析为.NET DateTime

.net javascript datetime json date

7
推荐指数
1
解决办法
7762
查看次数

附加HTML转义文本:jQuery

我习惯使用jQuery的.append()方法将文本或HTML添加到预先存在的元素的末尾.我目前正在使用jQuery .text()来转义可能包含HTML的字符串.不幸的是,似乎没有一个jQuery方法将方法的结果附加.text()到元素而不是替换其内容.

有没有办法将这个转义文本附加到元素而不是替换?或者有没有更好的方法来转义包含HTML的字符串?

谢谢.

- 编辑 -

更多上下文:我正在动态构建HTML字符串,因此我需要能够以编程方式添加带有转义内容的多个元素.

html javascript jquery dom escaping

6
推荐指数
2
解决办法
1万
查看次数

在Javascript中切换点击处理程序

我有一个HTML按钮,我使用jQuery附加一个事件bind(),如下所示:

$('#mybutton').bind('click', myFirstHandlerFunction);
Run Code Online (Sandbox Code Playgroud)

myFirstHandlerFunction,我希望这个处理程序用一个新的处理程序替换自己mySecondHandlerFunction,像这样:

function myFirstHandlerFunction(e) {
    $(this).unbind('click', myFirstHandlerFunction).bind('click', mySecondHandlerFunction);
}
Run Code Online (Sandbox Code Playgroud)

在第二次单击处理程序中mySecondHandlerFunction,我想将按钮切换回其原始状态:取消绑定mySecondHandlerFunction处理程序并重新附加原始处理程序myFirstHandlerFunction,如下所示:

function mySecondHandlerFunction(e) {
    $(this).unbind('click', mySecondHandlerFunction).bind('click', myFirstHandlerFunction);
}
Run Code Online (Sandbox Code Playgroud)

除了一个小细节之外,这很好用:因为click事件还没有通过每个按钮的点击处理程序传播,所以click事件被传递给按钮的下一个单击处理程序,它恰好是刚刚绑定的处理程序以前的处理程序.最终结果mySecondHandlerFunction在执行后立即myFirstHandlerFunction执行.

通过调用e.stopPropagation()每个处理程序可以很容易地解决这个问题,但是这具有消除可能已独立附加的任何其他点击处理程序的负面副作用.

有没有办法在两个点击处理程序之间安全地和一致地切换,而不必停止点击事件的传播?

javascript jquery events click handler

6
推荐指数
2
解决办法
1万
查看次数

即使工具箱打开,Firefox和RequireJS仍然从缓存中拉出

我在OSX 10.10.1上使用FirefoxDeveloperEdition 36.我在工具箱的设置面板中启用了"禁用缓存(工具箱打开时)"选项:

禁用缓存(工具箱打开时)已启用

但是,在我通过Preferences => Privacy => 清除您最近的历史记录手动清除缓存之前,我没有看到我的更改,即使我打开了工具箱.

我正在使用RequireJS来加载我的脚本依赖项. 看起来其他人遇到了RequireJS和缓存的问题,所以我猜这是根本问题.

这个选项是不是按照承诺工作,还是我做错了什么?如果可能的话,我想避免urlArgs解决方法.

我没有在任何其他浏览器中注意到这种行为.

javascript firefox caching requirejs firefox-developer-edition

6
推荐指数
1
解决办法
264
查看次数

如何使用SystemJS指定库依赖项?

使用SystemJS,如何指定一个库依赖于另一个库?例如,Bootstrap JavaScript库依赖于jQuery.基于SytemJS文档,我假设我将使用System.config.meta属性指定此依赖项:

System.config({
    baseUrl: './scripts',
    defaultJSExtensions: true,
    map: {
        jquery: './lib/jquery-2.2.0.min.js',
        bootstrap: './lib/bootstrap.min.js'
    },
    meta: {
        bootstrap: {
            deps: ['jquery']
        }
    }
});
System.import('./scripts/app.js');
Run Code Online (Sandbox Code Playgroud)

但这似乎没有效果.当我运行我的应用程序时,Bootstrap库会抛出一个Bootstrap's JavaScript requires jQuery错误 - 这意味着在jQuery之前加载了Bootstrap.

如何确保在Bootstrap之前始终加载jQuery?

javascript amd commonjs systemjs es6-module-loader

6
推荐指数
1
解决办法
3085
查看次数

通过模块增强向现有 TypeScript 接口添加属性没有效果

我有一个依赖于@types/hapi. 我想向该模块中定义的类之一添加一个属性。我尝试通过模块增强定义我的新属性:

// my-custom-hapi-typings.d.ts
import * as hapi from 'hapi';

declare module hapi {
    interface Server {
        myProperty: string;
    }
}
Run Code Online (Sandbox Code Playgroud)

这不会导致任何编译器错误,但也不会将该myProperty属性添加到Server类中。当我尝试像这样引用该属性时,我仍然在项目的其他地方遇到错误:

// my-other-file.ts
import * as hapi from 'hapi';

const server = new hapi.Server({ ... });

// error: Property 'myProperty' does not exist on type 'Server'.
server.myProperty = 'hello'; 
Run Code Online (Sandbox Code Playgroud)

为什么 TypeScript 编译器似乎忽略了我的.d.ts文件?我是否需要“导入”该文件或以某种方式让 TypeScript 编译器知道该文件存在?我的印象是,只需将.d.ts文件放在源目录中就足以让 TypeScript 接受这些增强。

typescript typescript-typings typescript2.0 typescript-definitions typescript-declarations

6
推荐指数
1
解决办法
4574
查看次数

除非“--module”标志为“amd”或“system”,否则无法使用选项“outFile”编译模块

我正在使用 Typescript 构建 Node-Mongodb 服务器并在构建时收到此错误:

[14:57:05] Using gulpfile ~/Desktop/mean/gulpfile.js
[14:57:05] Starting 'default'...
[14:57:05] Finished 'default' after 9.48 ms
[14:57:06] Starting 'build'...
server/app.ts(1,1): error TS6131: Cannot compile modules using option 'outFile' unless the '--module' flag is 'amd' or 'system'.
TypeScript: 1 semantic error
TypeScript: emit succeeded (with errors)
[14:57:08] Finished 'build' after 2.17 s
Run Code Online (Sandbox Code Playgroud)

这是我的tsconfig.json

[14:57:05] Using gulpfile ~/Desktop/mean/gulpfile.js
[14:57:05] Starting 'default'...
[14:57:05] Finished 'default' after 9.48 ms
[14:57:06] Starting 'build'...
server/app.ts(1,1): error TS6131: Cannot compile modules using option …
Run Code Online (Sandbox Code Playgroud)

mongodb node.js typescript

6
推荐指数
1
解决办法
6249
查看次数

Flutter SafeArea:避免凹口,但忽略圆角

有没有办法检测并避免手机屏幕上的凹口(例如 iPhone X 中的摄像头凹口),但忽略屏幕的圆角?

例如,这是我在带有缺口的 iPhone 上处于横向模式的应用程序:

手机横向模式的屏幕截图

左侧的菜单很好——屏幕的圆角不会干扰按钮。

右侧的菜单显然有问题——缺口几乎完全遮住了中间的按钮。

我已经尝试过使用SafeAreawidget,但是这个小部件避免了凹口圆角,这导致布局如下:

与上面相同的屏幕截图,但包含在 SafeArea 小部件中

右侧菜单的位置合理(尽管很难看),但现在左侧菜单栏远离屏幕边缘浮动,试图避免圆角。

我怎样才能两全其美?我想要第一个屏幕截图中的左侧菜单栏和第二个屏幕截图中的右侧菜单栏。有没有办法配置SafeArea小部件以避免凹口而不是圆角?

android ios dart flutter safearea

6
推荐指数
1
解决办法
1163
查看次数